{
  "url": "https://unifast.dev/ko/docs/packages/node/toc/",
  "locale": "ko",
  "title": "toc()",
  "description": "Markdown/MDX에서 제목을 추출하여 CompileResult.toc에 채워 주는 TOC 플러그인을 생성합니다.",
  "section": "packages",
  "body": "```ts\n\n```\n\n## 시그니처\n\n```ts\nfunction toc(options?: TocPluginOptions): UnifastPlugin\n```\n\n## 매개변수\n\n### options?\n\nTOC 추출 설정\n\n| 속성 | 타입 | 기본값 | 설명 |\n|----------|------|---------|-------------|\n| `maxDepth` | `number` | `3` | 포함할 최대 제목 레벨 (1-6). 값이 3이면 h1, h2, h3까지 포함합니다. |\n\n## 사용법\n\n```ts\n\nconst result = compile(md, {\n  plugins: [\n    toc({\n      maxDepth: 3,\n    }),\n  ],\n});\n\nconsole.log(result.toc);\n// [\n//   { depth: 1, text: \"Introduction\", slug: \"introduction\" },\n//   { depth: 2, text: \"Getting Started\", slug: \"getting-started\" },\n//   { depth: 3, text: \"Installation\", slug: \"installation\" },\n// ]\n```\n\n## 예시\n\n### 기본 제목 추출\n\n```ts\n\nconst md = `# Introduction\n\n## Getting Started\n\n### Installation\n\n## API Reference\n\n### compile()\n\n### hastToHtml()`;\n\nconst result = compile(md, { plugins: [toc()] });\n\nconsole.log(result.toc);\n// [\n//   { depth: 1, text: \"Introduction\", slug: \"introduction\" },\n//   { depth: 2, text: \"Getting Started\", slug: \"getting-started\" },\n//   { depth: 3, text: \"Installation\", slug: \"installation\" },\n//   { depth: 2, text: \"API Reference\", slug: \"api-reference\" },\n//   { depth: 3, text: \"compile()\", slug: \"compile\" },\n//   { depth: 3, text: \"hastToHtml()\", slug: \"hasttohtml\" },\n// ]\n```\n\n### 깊이 제한\n\n```ts\n\nconst result = compile(md, {\n  plugins: [toc({ maxDepth: 2 })],\n});\n\nconsole.log(result.toc);\n// h1과 h2 제목만 포함됩니다\n// [\n//   { depth: 1, text: \"Introduction\", slug: \"introduction\" },\n//   { depth: 2, text: \"Getting Started\", slug: \"getting-started\" },\n//   { depth: 2, text: \"API Reference\", slug: \"api-reference\" },\n// ]\n```\n\n### TOC 내비게이션 렌더링\n\n```tsx\n\nconst result = compile(md, { plugins: [toc()] });\n\nfunction TableOfContents() {\n  return (\n    <nav>\n      <ul>\n        {result.toc.map((entry) => (\n          <li key={entry.slug} style={{ marginLeft: (entry.depth - 1) * 16 }}>\n            <a href={`#${entry.slug}`}>{entry.text}</a>\n          </li>\n        ))}\n      </ul>\n    </nav>\n  );\n}\n```",
  "alternates": [
    {
      "locale": "en",
      "url": "https://unifast.dev/docs/packages/node/toc/",
      "api": "https://unifast.dev//api/docs/packages/node/toc.json"
    },
    {
      "locale": "ja",
      "url": "https://unifast.dev/ja/docs/packages/node/toc/",
      "api": "https://unifast.dev//api/ja/docs/packages/node/toc.json"
    },
    {
      "locale": "zh-CN",
      "url": "https://unifast.dev/zh-CN/docs/packages/node/toc/",
      "api": "https://unifast.dev//api/zh-CN/docs/packages/node/toc.json"
    },
    {
      "locale": "zh-TW",
      "url": "https://unifast.dev/zh-TW/docs/packages/node/toc/",
      "api": "https://unifast.dev//api/zh-TW/docs/packages/node/toc.json"
    },
    {
      "locale": "ko",
      "url": "https://unifast.dev/ko/docs/packages/node/toc/",
      "api": "https://unifast.dev//api/ko/docs/packages/node/toc.json"
    },
    {
      "locale": "fr",
      "url": "https://unifast.dev/fr/docs/packages/node/toc/",
      "api": "https://unifast.dev//api/fr/docs/packages/node/toc.json"
    },
    {
      "locale": "it",
      "url": "https://unifast.dev/it/docs/packages/node/toc/",
      "api": "https://unifast.dev//api/it/docs/packages/node/toc.json"
    },
    {
      "locale": "es",
      "url": "https://unifast.dev/es/docs/packages/node/toc/",
      "api": "https://unifast.dev//api/es/docs/packages/node/toc.json"
    },
    {
      "locale": "pt-BR",
      "url": "https://unifast.dev/pt-BR/docs/packages/node/toc/",
      "api": "https://unifast.dev//api/pt-BR/docs/packages/node/toc.json"
    },
    {
      "locale": "de",
      "url": "https://unifast.dev/de/docs/packages/node/toc/",
      "api": "https://unifast.dev//api/de/docs/packages/node/toc.json"
    },
    {
      "locale": "ru",
      "url": "https://unifast.dev/ru/docs/packages/node/toc/",
      "api": "https://unifast.dev//api/ru/docs/packages/node/toc.json"
    },
    {
      "locale": "hi",
      "url": "https://unifast.dev/hi/docs/packages/node/toc/",
      "api": "https://unifast.dev//api/hi/docs/packages/node/toc.json"
    },
    {
      "locale": "id",
      "url": "https://unifast.dev/id/docs/packages/node/toc/",
      "api": "https://unifast.dev//api/id/docs/packages/node/toc.json"
    },
    {
      "locale": "tr",
      "url": "https://unifast.dev/tr/docs/packages/node/toc/",
      "api": "https://unifast.dev//api/tr/docs/packages/node/toc.json"
    },
    {
      "locale": "vi",
      "url": "https://unifast.dev/vi/docs/packages/node/toc/",
      "api": "https://unifast.dev//api/vi/docs/packages/node/toc.json"
    }
  ]
}
