{
  "url": "https://unifast.dev/ko/docs/packages/highlight/overview/",
  "locale": "ko",
  "title": "@unifast/highlight",
  "description": "HAST 변환을 통한 unifast용 highlight.js 기반 구문 강조 플러그인",
  "section": "packages",
  "body": "## 개요\n\n`@unifast/highlight`는 [lowlight](https://github.com/wooorm/lowlight)(highlight.js 래퍼)로 구동되는 구문 강조를 제공합니다. Rust에서 강조를 실행하는 빌트인 `syntect()`와 `treeSitter()` 플러그인과 달리, 이 패키지는 컴파일 이후 JavaScript HAST 변환 단계에서 강조를 적용합니다. 덕분에 highlight.js의 방대한 언어 및 테마 생태계를 그대로 활용할 수 있습니다.\n\n## 설치\n\n## 빠른 시작\n\n```ts\n\nconst md = `\n\\`\\`\\`javascript\nconst x = 42;\nconsole.log(x);\n\\`\\`\\`\n`;\n\nconst result = compile(md, {\n  plugins: [highlight()],\n});\n\nconsole.log(result.output);\n// highlight.js의 CSS 클래스로 강조된 코드 블록\n```\n\n## 동작 방식\n\n1. Rust 컴파일러가 강조되지 않은 `<pre><code>` 블록을 포함한 HAST를 생성합니다.\n2. `highlight()` 플러그인의 `hastTransform`이 HAST 트리를 순회합니다.\n3. `language-*` 클래스를 가진 각 `<code>` 요소에 대해 lowlight가 코드를 강조합니다.\n4. 강조된 HAST 노드가 원래 자식을 대체합니다.\n\n이 작업은 HAST 변환으로 실행되므로, Rust 네이티브 강조(`syntect` / `treeSitter`)가 비활성화되어야 합니다. 플러그인은 컴파일 옵션에 `highlight.enabled: false`를 자동으로 설정합니다.\n\n## Exports 요약\n\n| Export | 종류 | 설명 |\n|--------|------|-------------|\n| `highlight` | function | highlight.js HAST 변환 플러그인 생성 |",
  "alternates": [
    {
      "locale": "en",
      "url": "https://unifast.dev/docs/packages/highlight/overview/",
      "api": "https://unifast.dev//api/docs/packages/highlight/overview.json"
    },
    {
      "locale": "ja",
      "url": "https://unifast.dev/ja/docs/packages/highlight/overview/",
      "api": "https://unifast.dev//api/ja/docs/packages/highlight/overview.json"
    },
    {
      "locale": "zh-CN",
      "url": "https://unifast.dev/zh-CN/docs/packages/highlight/overview/",
      "api": "https://unifast.dev//api/zh-CN/docs/packages/highlight/overview.json"
    },
    {
      "locale": "zh-TW",
      "url": "https://unifast.dev/zh-TW/docs/packages/highlight/overview/",
      "api": "https://unifast.dev//api/zh-TW/docs/packages/highlight/overview.json"
    },
    {
      "locale": "ko",
      "url": "https://unifast.dev/ko/docs/packages/highlight/overview/",
      "api": "https://unifast.dev//api/ko/docs/packages/highlight/overview.json"
    },
    {
      "locale": "fr",
      "url": "https://unifast.dev/fr/docs/packages/highlight/overview/",
      "api": "https://unifast.dev//api/fr/docs/packages/highlight/overview.json"
    },
    {
      "locale": "it",
      "url": "https://unifast.dev/it/docs/packages/highlight/overview/",
      "api": "https://unifast.dev//api/it/docs/packages/highlight/overview.json"
    },
    {
      "locale": "es",
      "url": "https://unifast.dev/es/docs/packages/highlight/overview/",
      "api": "https://unifast.dev//api/es/docs/packages/highlight/overview.json"
    },
    {
      "locale": "pt-BR",
      "url": "https://unifast.dev/pt-BR/docs/packages/highlight/overview/",
      "api": "https://unifast.dev//api/pt-BR/docs/packages/highlight/overview.json"
    },
    {
      "locale": "de",
      "url": "https://unifast.dev/de/docs/packages/highlight/overview/",
      "api": "https://unifast.dev//api/de/docs/packages/highlight/overview.json"
    },
    {
      "locale": "ru",
      "url": "https://unifast.dev/ru/docs/packages/highlight/overview/",
      "api": "https://unifast.dev//api/ru/docs/packages/highlight/overview.json"
    },
    {
      "locale": "hi",
      "url": "https://unifast.dev/hi/docs/packages/highlight/overview/",
      "api": "https://unifast.dev//api/hi/docs/packages/highlight/overview.json"
    },
    {
      "locale": "id",
      "url": "https://unifast.dev/id/docs/packages/highlight/overview/",
      "api": "https://unifast.dev//api/id/docs/packages/highlight/overview.json"
    },
    {
      "locale": "tr",
      "url": "https://unifast.dev/tr/docs/packages/highlight/overview/",
      "api": "https://unifast.dev//api/tr/docs/packages/highlight/overview.json"
    },
    {
      "locale": "vi",
      "url": "https://unifast.dev/vi/docs/packages/highlight/overview/",
      "api": "https://unifast.dev//api/vi/docs/packages/highlight/overview.json"
    }
  ]
}
