{
  "url": "https://unifast.dev/fr/docs/packages/node/overview/",
  "locale": "fr",
  "title": "@unifast/node",
  "description": "Liaison Node.js pour le compilateur Markdown/MDX unifast, propulsée par Rust natif",
  "section": "packages",
  "body": "## Vue d'ensemble\n\n`@unifast/node` est le point d'entrée principal pour utiliser unifast dans Node.js. Il expose la fonction [`compile()`](/docs/packages/node/compile) qui invoque le compilateur natif Rust via napi-rs, pour des performances maximales. Il prend également en charge le système de plugins, permettant d'appliquer des transformations HAST en JavaScript après l'étape de compilation Rust.\n\n## Installation\n\n> L'extension native Rust doit être compilée au préalable. Exécutez `cargo build -p unifast-bindings-node --release` si le binaire natif n'est pas disponible.\n\n## Démarrage rapide\n\n```ts\n\nconst result = compile(\"# Hello, **world**!\");\nconsole.log(result.output);\n// <h1 id=\"hello-world\">Hello, <strong>world</strong>!</h1>\n```\n\n## Pipeline des plugins\n\nLorsque des plugins sont fournis, `compile()` exécute le pipeline suivant :\n\n1. **Extraction des plugins** - Sépare `plugins` du reste des options\n2. **Fusion des options** - Fusionne en profondeur les `options` de chaque plugin dans les options de compilation\n3. **Forçage du HAST** - Si l'un des plugins possède un `hastTransform`, l'appel natif utilise `outputKind: \"hast\"`\n4. **Compilation native** - Appelle le compilateur Rust via napi-rs\n5. **Transformations HAST** - Applique dans l'ordre les `hastTransform` de chaque plugin\n6. **Conversion de la sortie** - Si l'utilisateur n'a pas demandé de sortie HAST, reconvertit en HTML via `hastToHtml`\n\n## Plugins intégrés\n\nLes fabriques de plugins suivantes sont incluses — aucune installation séparée n'est nécessaire :\n\n`gfm`, `frontmatter`, `sanitize`, `syntect`, `treeSitter`, `toc`, `externalLinks`, `autolinkHeadings`, `smartypants`, `wikiLink`, `codeImport`, `emoji`, `breaks`, `math`, `githubAlert`, `sectionize`, `directive`, `definitionList`, `rubyAnnotation`, `cjk`\n\n```ts\n\nconst result = compile(source, {\n  plugins: [gfm(), frontmatter(), syntect()],\n});\n```\n\n## Résumé des exports\n\n| Export | Nature | Description |\n|--------|------|-------------|\n| `compile` | fonction | Compile du Markdown/MDX vers du HTML ou d'autres formats |\n| `gfm`, `frontmatter`, ... | fonction | Fabriques de plugins intégrés (20 au total) |\n| `hastToHtml` | fonction | Sérialiseur HAST vers HTML (réexporté depuis `@unifast/core`) |\n| `CompileOptions` | type | Configuration de compilation |\n| `CompileResult` | type | Résultat de compilation |\n| `UnifastPlugin` | type | Interface de plugin |\n| `TocEntry` | type | Entrée de table des matières |\n| `HastRoot` | type | Nœud racine HAST |\n| `HastElement` | type | Nœud élément HAST |\n| `HastText` | type | Nœud texte HAST |\n| `HastNode` | type | Union de tous les types de nœuds HAST |\n| `UnifastError` | classe | Classe d'erreur de base |\n| `ParseError` | classe | Classe d'erreur d'analyse |\n| `CompileError` | classe | Classe d'erreur de compilation |",
  "alternates": [
    {
      "locale": "en",
      "url": "https://unifast.dev/docs/packages/node/overview/",
      "api": "https://unifast.dev//api/docs/packages/node/overview.json"
    },
    {
      "locale": "ja",
      "url": "https://unifast.dev/ja/docs/packages/node/overview/",
      "api": "https://unifast.dev//api/ja/docs/packages/node/overview.json"
    },
    {
      "locale": "zh-CN",
      "url": "https://unifast.dev/zh-CN/docs/packages/node/overview/",
      "api": "https://unifast.dev//api/zh-CN/docs/packages/node/overview.json"
    },
    {
      "locale": "zh-TW",
      "url": "https://unifast.dev/zh-TW/docs/packages/node/overview/",
      "api": "https://unifast.dev//api/zh-TW/docs/packages/node/overview.json"
    },
    {
      "locale": "ko",
      "url": "https://unifast.dev/ko/docs/packages/node/overview/",
      "api": "https://unifast.dev//api/ko/docs/packages/node/overview.json"
    },
    {
      "locale": "fr",
      "url": "https://unifast.dev/fr/docs/packages/node/overview/",
      "api": "https://unifast.dev//api/fr/docs/packages/node/overview.json"
    },
    {
      "locale": "it",
      "url": "https://unifast.dev/it/docs/packages/node/overview/",
      "api": "https://unifast.dev//api/it/docs/packages/node/overview.json"
    },
    {
      "locale": "es",
      "url": "https://unifast.dev/es/docs/packages/node/overview/",
      "api": "https://unifast.dev//api/es/docs/packages/node/overview.json"
    },
    {
      "locale": "pt-BR",
      "url": "https://unifast.dev/pt-BR/docs/packages/node/overview/",
      "api": "https://unifast.dev//api/pt-BR/docs/packages/node/overview.json"
    },
    {
      "locale": "de",
      "url": "https://unifast.dev/de/docs/packages/node/overview/",
      "api": "https://unifast.dev//api/de/docs/packages/node/overview.json"
    },
    {
      "locale": "ru",
      "url": "https://unifast.dev/ru/docs/packages/node/overview/",
      "api": "https://unifast.dev//api/ru/docs/packages/node/overview.json"
    },
    {
      "locale": "hi",
      "url": "https://unifast.dev/hi/docs/packages/node/overview/",
      "api": "https://unifast.dev//api/hi/docs/packages/node/overview.json"
    },
    {
      "locale": "id",
      "url": "https://unifast.dev/id/docs/packages/node/overview/",
      "api": "https://unifast.dev//api/id/docs/packages/node/overview.json"
    },
    {
      "locale": "tr",
      "url": "https://unifast.dev/tr/docs/packages/node/overview/",
      "api": "https://unifast.dev//api/tr/docs/packages/node/overview.json"
    },
    {
      "locale": "vi",
      "url": "https://unifast.dev/vi/docs/packages/node/overview/",
      "api": "https://unifast.dev//api/vi/docs/packages/node/overview.json"
    }
  ]
}
