{
  "url": "https://unifast.dev/ko/docs/packages/core/hast-to-html/",
  "locale": "ko",
  "title": "hastToHtml()",
  "description": "HAST 루트 노드를 HTML 문자열로 직렬화합니다.",
  "section": "packages",
  "body": "```ts\nimport { hastToHtml } from \"@unifast/core\";\n```\n\n## 시그니처\n\n```ts\nfunction hastToHtml(hast: HastRoot): string\n```\n\n## 매개변수\n\n### hast\n\n| 속성 | 타입 | 기본값 | 설명 |\n|----------|------|---------|-------------|\n| `type` | `\"root\"` | — | 노드 타입 식별자 |\n| `children` | `HastNode[]` | — | 트리의 자식 노드 |\n\n## 반환값\n\n`string` — 직렬화된 HTML 문자열.\n\n## 사용법\n\n```ts\nimport { hastToHtml } from \"@unifast/core\";\nimport type { HastRoot } from \"@unifast/core\";\n\nconst hast: HastRoot = {\n  type: \"root\",\n  children: [\n    {\n      type: \"element\",\n      tagName: \"h1\",\n      properties: { id: \"hello\", className: [\"title\", \"main\"] },\n      children: [\n        { type: \"text\", value: \"Hello \" },\n        {\n          type: \"element\",\n          tagName: \"strong\",\n          properties: {},\n          children: [{ type: \"text\", value: \"world\" }],\n        },\n      ],\n    },\n  ],\n};\n\nconst html = hastToHtml(hast);\n\nconsole.log(html);\n// <h1 class=\"title main\" id=\"hello\">Hello <strong>world</strong></h1>\n```\n\n## 예시\n\n### 기본 직렬화\n\n```ts\nimport { hastToHtml } from \"@unifast/core\";\nimport type { HastRoot } from \"@unifast/core\";\n\nconst hast: HastRoot = {\n  type: \"root\",\n  children: [\n    {\n      type: \"element\",\n      tagName: \"p\",\n      properties: {},\n      children: [\n        { type: \"text\", value: \"This is \" },\n        {\n          type: \"element\",\n          tagName: \"strong\",\n          properties: {},\n          children: [{ type: \"text\", value: \"bold\" }],\n        },\n        { type: \"text\", value: \" text.\" },\n      ],\n    },\n  ],\n};\n\nconsole.log(hastToHtml(hast));\n// <p>This is <strong>bold</strong> text.</p>\n```\n\n### 빈(void) 요소\n\n`<br>`, `<img>`, `<hr>` 등의 빈 요소는 자동으로 자체 닫힘 형태로 출력됩니다.\n\n```ts\nimport { hastToHtml } from \"@unifast/core\";\nimport type { HastRoot } from \"@unifast/core\";\n\nconst hast: HastRoot = {\n  type: \"root\",\n  children: [\n    {\n      type: \"element\",\n      tagName: \"img\",\n      properties: { src: \"photo.jpg\", alt: \"A photo\" },\n      children: [],\n    },\n  ],\n};\n\nconsole.log(hastToHtml(hast));\n// <img alt=\"A photo\" src=\"photo.jpg\" />\n```\n\n### compile() 출력과 함께 사용\n\n```ts\nimport { compile } from \"@unifast/node\";\nimport { hastToHtml } from \"@unifast/core\";\nimport type { HastRoot } from \"@unifast/core\";\n\nconst result = compile(\"**bold text**\", { outputKind: \"hast\" });\nconst hast: HastRoot = JSON.parse(result.output as string);\n\nconsole.log(hastToHtml(hast));\n// <p><strong>bold text</strong></p>\n```\n\n### 원본 HTML 패스스루\n\n```ts\nimport { hastToHtml } from \"@unifast/core\";\nimport type { HastRoot } from \"@unifast/core\";\n\nconst hast: HastRoot = {\n  type: \"root\",\n  children: [\n    { type: \"raw\", value: \"<div class=\\\"custom\\\">Raw HTML</div>\" },\n  ],\n};\n\nconsole.log(hastToHtml(hast));\n// <div class=\"custom\">Raw HTML</div>\n```\n\n## 동작\n\n- **HTML 이스케이프:** 텍스트 콘텐츠는 이스케이프됩니다 (`&`, `<`, `>`, `\"`).\n- **Void 요소:** `area`, `base`, `br`, `col`, `embed`, `hr`, `img`, `input`, `link`, `meta`, `param`, `source`, `track`, `wbr`은 자체 닫힘 형태로 출력됩니다.\n- **속성:** 알파벳 순으로 정렬됩니다. `className` 배열은 공백으로 연결되어 `class`로 렌더링됩니다. boolean `true`는 값 없는 속성으로, `false`/`null`/`undefined`는 생략됩니다.\n- **주석:** `<!--value-->` 형태로 렌더링됩니다.\n- **Doctype:** `<!DOCTYPE html>`로 렌더링됩니다.\n- **Raw 노드:** 이스케이프 없이 그대로 출력됩니다.",
  "alternates": [
    {
      "locale": "en",
      "url": "https://unifast.dev/docs/packages/core/hast-to-html/",
      "api": "https://unifast.dev//api/docs/packages/core/hast-to-html.json"
    },
    {
      "locale": "ja",
      "url": "https://unifast.dev/ja/docs/packages/core/hast-to-html/",
      "api": "https://unifast.dev//api/ja/docs/packages/core/hast-to-html.json"
    },
    {
      "locale": "zh-CN",
      "url": "https://unifast.dev/zh-CN/docs/packages/core/hast-to-html/",
      "api": "https://unifast.dev//api/zh-CN/docs/packages/core/hast-to-html.json"
    },
    {
      "locale": "zh-TW",
      "url": "https://unifast.dev/zh-TW/docs/packages/core/hast-to-html/",
      "api": "https://unifast.dev//api/zh-TW/docs/packages/core/hast-to-html.json"
    },
    {
      "locale": "ko",
      "url": "https://unifast.dev/ko/docs/packages/core/hast-to-html/",
      "api": "https://unifast.dev//api/ko/docs/packages/core/hast-to-html.json"
    },
    {
      "locale": "fr",
      "url": "https://unifast.dev/fr/docs/packages/core/hast-to-html/",
      "api": "https://unifast.dev//api/fr/docs/packages/core/hast-to-html.json"
    },
    {
      "locale": "it",
      "url": "https://unifast.dev/it/docs/packages/core/hast-to-html/",
      "api": "https://unifast.dev//api/it/docs/packages/core/hast-to-html.json"
    },
    {
      "locale": "es",
      "url": "https://unifast.dev/es/docs/packages/core/hast-to-html/",
      "api": "https://unifast.dev//api/es/docs/packages/core/hast-to-html.json"
    },
    {
      "locale": "pt-BR",
      "url": "https://unifast.dev/pt-BR/docs/packages/core/hast-to-html/",
      "api": "https://unifast.dev//api/pt-BR/docs/packages/core/hast-to-html.json"
    },
    {
      "locale": "de",
      "url": "https://unifast.dev/de/docs/packages/core/hast-to-html/",
      "api": "https://unifast.dev//api/de/docs/packages/core/hast-to-html.json"
    },
    {
      "locale": "ru",
      "url": "https://unifast.dev/ru/docs/packages/core/hast-to-html/",
      "api": "https://unifast.dev//api/ru/docs/packages/core/hast-to-html.json"
    },
    {
      "locale": "hi",
      "url": "https://unifast.dev/hi/docs/packages/core/hast-to-html/",
      "api": "https://unifast.dev//api/hi/docs/packages/core/hast-to-html.json"
    },
    {
      "locale": "id",
      "url": "https://unifast.dev/id/docs/packages/core/hast-to-html/",
      "api": "https://unifast.dev//api/id/docs/packages/core/hast-to-html.json"
    },
    {
      "locale": "tr",
      "url": "https://unifast.dev/tr/docs/packages/core/hast-to-html/",
      "api": "https://unifast.dev//api/tr/docs/packages/core/hast-to-html.json"
    },
    {
      "locale": "vi",
      "url": "https://unifast.dev/vi/docs/packages/core/hast-to-html/",
      "api": "https://unifast.dev//api/vi/docs/packages/core/hast-to-html.json"
    }
  ]
}
