{
  "url": "https://unifast.dev/de/docs/packages/core/hast-to-html/",
  "locale": "de",
  "title": "hastToHtml()",
  "description": "Serialisiert einen HAST-Wurzelknoten in einen HTML-String.",
  "section": "packages",
  "body": "```ts\nimport { hastToHtml } from \"@unifast/core\";\n```\n\n## Signatur\n\n```ts\nfunction hastToHtml(hast: HastRoot): string\n```\n\n## Parameter\n\n### hast\n\n| Eigenschaft | Typ | Standard | Beschreibung |\n|----------|------|---------|-------------|\n| `type` | `\"root\"` | — | Bezeichner des Knotentyps |\n| `children` | `HastNode[]` | — | Kindknoten des Baums |\n\n## Rückgabewert\n\n`string` – Der serialisierte HTML-String.\n\n## Verwendung\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## Beispiele\n\n### Grundlegende Serialisierung\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-Elemente\n\nVoid-Elemente (`<br>`, `<img>`, `<hr>` usw.) werden automatisch selbstschließend ausgegeben:\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### Mit compile()-Ausgabe\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### Roh-HTML durchreichen\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## Verhalten\n\n- **HTML-Maskierung:** Textinhalte werden maskiert (`&`, `<`, `>`, `\"`)\n- **Void-Elemente:** `area`, `base`, `br`, `col`, `embed`, `hr`, `img`, `input`, `link`, `meta`, `param`, `source`, `track`, `wbr` werden selbstschließend ausgegeben\n- **Attribute:** Alphabetisch sortiert; `className`-Arrays werden mit Leerzeichen verbunden und als `class` gerendert; der boolesche Wert `true` wird als bloßes Attribut gerendert; `false`/`null`/`undefined` werden ausgelassen\n- **Kommentare:** Werden als `<!--value-->` gerendert\n- **Doctype:** Wird als `<!DOCTYPE html>` gerendert\n- **Raw-Knoten:** Werden unverändert und ohne Maskierung ausgegeben",
  "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"
    }
  ]
}
