{
  "url": "https://unifast.dev/ru/docs/packages/node/overview/",
  "locale": "ru",
  "title": "@unifast/node",
  "description": "Биндинг Node.js для компилятора Markdown/MDX unifast на основе нативного Rust",
  "section": "packages",
  "body": "## Обзор\n\n`@unifast/node` — основная точка входа для использования unifast в Node.js. Он предоставляет функцию [`compile()`](/docs/packages/node/compile), которая вызывает нативный компилятор на Rust через napi-rs для максимальной производительности. Также он поддерживает систему плагинов, позволяя применять HAST-преобразования в JavaScript после шага компиляции на Rust.\n\n## Установка\n\n> Нативное дополнение на Rust должно быть предварительно собрано. Выполните `cargo build -p unifast-bindings-node --release`, если нативный бинарник недоступен.\n\n## Быстрый старт\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## Конвейер плагинов\n\nКогда передаются плагины, `compile()` выполняет следующий конвейер:\n\n1. **Извлечение плагинов** — отделяет `plugins` от остальных параметров\n2. **Слияние параметров** — глубокое слияние `options` каждого плагина с параметрами компиляции\n3. **Принудительный HAST** — если у какого-либо плагина есть `hastTransform`, нативный вызов использует `outputKind: \"hast\"`\n4. **Нативная компиляция** — вызов компилятора на Rust через napi-rs\n5. **HAST-преобразования** — последовательное применение `hastTransform` каждого плагина\n6. **Преобразование вывода** — если пользователь не запросил вывод HAST, результат конвертируется обратно в HTML через `hastToHtml`\n\n## Встроенные плагины\n\nСледующие фабричные функции плагинов включены в пакет — отдельная установка не требуется:\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## Сводка экспортов\n\n| Экспорт | Вид | Описание |\n|--------|------|-------------|\n| `compile` | функция | Компилирует Markdown/MDX в HTML и другие форматы |\n| `gfm`, `frontmatter`, ... | функция | Фабрики встроенных плагинов (всего 20) |\n| `hastToHtml` | функция | Сериализатор HAST в HTML (реэкспорт из `@unifast/core`) |\n| `CompileOptions` | тип | Конфигурация компиляции |\n| `CompileResult` | тип | Результат компиляции |\n| `UnifastPlugin` | тип | Интерфейс плагина |\n| `TocEntry` | тип | Элемент оглавления |\n| `HastRoot` | тип | Корневой узел HAST |\n| `HastElement` | тип | Узел-элемент HAST |\n| `HastText` | тип | Текстовый узел HAST |\n| `HastNode` | тип | Объединение всех типов узлов HAST |\n| `UnifastError` | класс | Базовый класс ошибок |\n| `ParseError` | класс | Класс ошибок парсинга |\n| `CompileError` | класс | Класс ошибок компиляции |",
  "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"
    }
  ]
}
