docmk 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.claude/skills/pdf/SKILL.md +89 -0
- package/.claude/skills/web-scraping/SKILL.md +78 -0
- package/CLAUDE.md +90 -0
- package/bin/docmk.js +3 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +636 -0
- package/dist/index.js.map +1 -0
- package/final-site/assets/main-B4orIFxK.css +1 -0
- package/final-site/assets/main-CSoKXua6.js +25 -0
- package/final-site/favicon.svg +4 -0
- package/final-site/index.html +26 -0
- package/final-site/robots.txt +4 -0
- package/final-site/sitemap.xml +14 -0
- package/my-docs/api/README.md +152 -0
- package/my-docs/api/advanced.md +260 -0
- package/my-docs/getting-started/README.md +24 -0
- package/my-docs/tutorials/README.md +272 -0
- package/my-docs/tutorials/customization.md +492 -0
- package/package.json +59 -0
- package/postcss.config.js +6 -0
- package/site/assets/main-BZUsYUCF.css +1 -0
- package/site/assets/main-q6laQtCD.js +114 -0
- package/site/favicon.svg +4 -0
- package/site/index.html +23 -0
- package/site/robots.txt +4 -0
- package/site/sitemap.xml +34 -0
- package/site-output/assets/main-B4orIFxK.css +1 -0
- package/site-output/assets/main-CSoKXua6.js +25 -0
- package/site-output/favicon.svg +4 -0
- package/site-output/index.html +26 -0
- package/site-output/robots.txt +4 -0
- package/site-output/sitemap.xml +14 -0
- package/src/builder/index.ts +189 -0
- package/src/builder/vite-dev.ts +117 -0
- package/src/cli/commands/build.ts +48 -0
- package/src/cli/commands/dev.ts +53 -0
- package/src/cli/commands/preview.ts +57 -0
- package/src/cli/index.ts +42 -0
- package/src/client/App.vue +15 -0
- package/src/client/components/SearchBox.vue +204 -0
- package/src/client/components/Sidebar.vue +18 -0
- package/src/client/components/SidebarItem.vue +108 -0
- package/src/client/index.html +21 -0
- package/src/client/layouts/AppLayout.vue +99 -0
- package/src/client/lib/utils.ts +6 -0
- package/src/client/main.ts +42 -0
- package/src/client/pages/Home.vue +279 -0
- package/src/client/pages/SkillPage.vue +565 -0
- package/src/client/router.ts +16 -0
- package/src/client/styles/global.css +92 -0
- package/src/client/utils/routes.ts +69 -0
- package/src/parser/index.ts +253 -0
- package/src/scanner/index.ts +127 -0
- package/src/types/index.ts +45 -0
- package/tailwind.config.js +65 -0
- package/test-build/assets/main-C2ARPC0e.css +1 -0
- package/test-build/assets/main-CHIQpV3B.js +25 -0
- package/test-build/favicon.svg +4 -0
- package/test-build/index.html +47 -0
- package/test-build/robots.txt +4 -0
- package/test-build/sitemap.xml +19 -0
- package/test-dist/assets/main-B4orIFxK.css +1 -0
- package/test-dist/assets/main-CSoKXua6.js +25 -0
- package/test-dist/favicon.svg +4 -0
- package/test-dist/index.html +26 -0
- package/test-dist/robots.txt +4 -0
- package/test-dist/sitemap.xml +14 -0
- package/tsconfig.json +30 -0
- package/tsup.config.ts +13 -0
- package/vite.config.ts +21 -0
package/site/index.html
ADDED
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
<!DOCTYPE html>
|
|
2
|
+
<html lang="en">
|
|
3
|
+
<head>
|
|
4
|
+
<meta charset="UTF-8">
|
|
5
|
+
<link rel="icon" href="/favicon.svg" type="image/svg+xml">
|
|
6
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
7
|
+
<meta name="description" content="Modern documentation site">
|
|
8
|
+
<title>Documentation</title>
|
|
9
|
+
<script>globalThis.__DOCGEN_CONFIG__=JSON.parse(decodeURIComponent(escape(atob("{"siteConfig":{"title":"Documentation","description":"Documentation generated from source directory","baseUrl":"/","skillsDir":"/Users/pan/docgen/my-docs","outputDir":"/Users/pan/docgen/site"},"navigation":[{"text":"Api","children":[{"text":"API 参考","link":"/api/README"},{"text":"高级用法","link":"/api/advanced"}]},{"text":"Configuration"},{"text":"Faq"},{"text":"Getting Started","children":[{"text":"快速开始","link":"/getting-started/README"}]},{"text":"Tutorials","children":[{"text":"教程指南","link":"/tutorials/README"},{"text":"自定义文档站点","link":"/tutorials/customization"}]}],"files":[{"path":"/Users/pan/docgen/my-docs/api/README.md","name":"README.md","title":"API 参考","description":"DocGen API 完整参考文档","content":"\n# API 参考\n\nDocGen 提供了简洁而强大的 API，用于生成和管理文档站点。\n\n## 核心 API\n\n### scanSkillsDirectory()\n\n扫描指定目录，收集所有 Markdown 文件。\n\n```typescript\nasync function scanSkillsDirectory(dirPath: string): Promise<SkillDirectory[]>\n```\n\n**参数：**\n- `dirPath` (string): 要扫描的目录路径\n\n**返回值：**\n- `Promise<SkillDirectory[]>`: 目录结构数组\n\n**示例：**\n\n```typescript\nimport { scanSkillsDirectory } from 'docgen'\n\nconst directories = await scanSkillsDirectory('./docs')\nconsole.log(`找到 ${directories.length} 个目录`)\n```\n\n### parseSkillsToConfig()\n\n将扫描的目录结构解析为配置对象。\n\n```typescript\nasync function parseSkillsToConfig(\n  directories: SkillDirectory[],\n  siteConfig: SiteConfig\n): Promise<DocGenConfig>\n```\n\n**参数：**\n- `directories` (SkillDirectory[]): 目录结构数组\n- `siteConfig` (SiteConfig): 站点配置对象\n\n**返回值：**\n- `Promise<DocGenConfig>`: 完整的文档配置\n\n**示例：**\n\n```typescript\nconst config = await parseSkillsToConfig(directories, {\n  title: '我的文档',\n  description: '项目文档站点',\n  baseUrl: '/',\n  skillsDir: './docs',\n  outputDir: './dist'\n})\n```\n\n## 类型定义\n\n### SkillFile\n\n表示单个 Markdown 文件。\n\n```typescript\ninterface SkillFile {\n  path: string           // 文件绝对路径\n  name: string           // 文件名\n  title?: string         // 文档标题\n  description?: string   // 文档描述\n  content: string        // Markdown 内容\n  frontmatter: Record<string, any>  // 前置元数据\n  lastModified: number   // 最后修改时间戳\n}\n```\n\n### SiteConfig\n\n站点配置对象。\n\n```typescript\ninterface SiteConfig {\n  title: string          // 站点标题\n  description: string    // 站点描述\n  baseUrl: string        // 基础 URL\n  skillsDir: string      // 源文件目录\n  outputDir: string      // 输出目录\n}\n```\n\n## CLI 命令\n\n### dev\n\n启动开发服务器。\n\n```bash\ndocgen dev [options]\n```\n\n**选项：**\n- `--dir <path>`: 源文件目录（默认：`./docs`）\n- `--port <number>`: 端口号（默认：`3000`）\n\n### build\n\n构建静态站点。\n\n```bash\ndocgen build [options]\n```\n\n**选项：**\n- `--dir <path>`: 源文件目录（默认：`./docs`）\n- `--output <path>`: 输出目录（默认：`./dist`）\n\n### preview\n\n预览构建后的站点。\n\n```bash\ndocgen preview [options]\n```\n\n**选项：**\n- `--output <path>`: 站点目录（默认：`./dist`）\n- `--port <number>`: 端口号（默认：`4173`）\n\n## 错误处理\n\n所有异步函数都会抛出错误，建议使用 try-catch 处理：\n\n```typescript\ntry {\n  const directories = await scanSkillsDirectory('./docs')\n} catch (error) {\n  console.error('扫描失败:', error)\n}\n```\n\n## 最佳实践\n\n1. **使用 TypeScript**：获得完整的类型提示\n2. **错误处理**：始终捕获异步操作的错误\n3. **路径规范**：使用绝对路径避免路径问题\n4. **配置验证**：构建前验证配置对象的完整性\n","frontmatter":{"title":"API 参考","description":"DocGen API 完整参考文档","html":"<h1>API 参考</h1>\n<p>DocGen 提供了简洁而强大的 API，用于生成和管理文档站点。</p>\n<h2>核心 API</h2>\n<h3>scanSkillsDirectory()</h3>\n<p>扫描指定目录，收集所有 Markdown 文件。</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">async</span><span style=\"color:#F97583\"> function</span><span style=\"color:#B392F0\"> scanSkillsDirectory</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">dirPath</span><span style=\"color:#F97583\">:</span><span style=\"color:#79B8FF\"> string</span><span style=\"color:#E1E4E8\">)</span><span style=\"color:#F97583\">:</span><span style=\"color:#B392F0\"> Promise</span><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#B392F0\">SkillDirectory</span><span style=\"color:#E1E4E8\">[]></span></span>\n<span class=\"line\"></span></code></pre>\n<p><strong>参数：</strong></p>\n<ul>\n<li><code>dirPath</code> (string): 要扫描的目录路径</li>\n</ul>\n<p><strong>返回值：</strong></p>\n<ul>\n<li><code>Promise&lt;SkillDirectory[]&gt;</code>: 目录结构数组</li>\n</ul>\n<p><strong>示例：</strong></p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#E1E4E8\"> { scanSkillsDirectory } </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> 'docgen'</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#79B8FF\"> directories</span><span style=\"color:#F97583\"> =</span><span style=\"color:#F97583\"> await</span><span style=\"color:#B392F0\"> scanSkillsDirectory</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'./docs'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">console.</span><span style=\"color:#B392F0\">log</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">`找到 ${</span><span style=\"color:#E1E4E8\">directories</span><span style=\"color:#9ECBFF\">.</span><span style=\"color:#79B8FF\">length</span><span style=\"color:#9ECBFF\">} 个目录`</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>parseSkillsToConfig()</h3>\n<p>将扫描的目录结构解析为配置对象。</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">async</span><span style=\"color:#F97583\"> function</span><span style=\"color:#B392F0\"> parseSkillsToConfig</span><span style=\"color:#E1E4E8\">(</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  directories</span><span style=\"color:#F97583\">:</span><span style=\"color:#B392F0\"> SkillDirectory</span><span style=\"color:#E1E4E8\">[],</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  siteConfig</span><span style=\"color:#F97583\">:</span><span style=\"color:#B392F0\"> SiteConfig</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">)</span><span style=\"color:#F97583\">:</span><span style=\"color:#B392F0\"> Promise</span><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#B392F0\">DocGenConfig</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span></code></pre>\n<p><strong>参数：</strong></p>\n<ul>\n<li><code>directories</code> (SkillDirectory[]): 目录结构数组</li>\n<li><code>siteConfig</code> (SiteConfig): 站点配置对象</li>\n</ul>\n<p><strong>返回值：</strong></p>\n<ul>\n<li><code>Promise&lt;DocGenConfig&gt;</code>: 完整的文档配置</li>\n</ul>\n<p><strong>示例：</strong></p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#79B8FF\"> config</span><span style=\"color:#F97583\"> =</span><span style=\"color:#F97583\"> await</span><span style=\"color:#B392F0\"> parseSkillsToConfig</span><span style=\"color:#E1E4E8\">(directories, {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  title: </span><span style=\"color:#9ECBFF\">'我的文档'</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  description: </span><span style=\"color:#9ECBFF\">'项目文档站点'</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  baseUrl: </span><span style=\"color:#9ECBFF\">'/'</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  skillsDir: </span><span style=\"color:#9ECBFF\">'./docs'</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  outputDir: </span><span style=\"color:#9ECBFF\">'./dist'</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">})</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>类型定义</h2>\n<h3>SkillFile</h3>\n<p>表示单个 Markdown 文件。</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">interface</span><span style=\"color:#B392F0\"> SkillFile</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  path</span><span style=\"color:#F97583\">:</span><span style=\"color:#79B8FF\"> string</span><span style=\"color:#6A737D\">           // 文件绝对路径</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  name</span><span style=\"color:#F97583\">:</span><span style=\"color:#79B8FF\"> string</span><span style=\"color:#6A737D\">           // 文件名</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  title</span><span style=\"color:#F97583\">?:</span><span style=\"color:#79B8FF\"> string</span><span style=\"color:#6A737D\">         // 文档标题</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  description</span><span style=\"color:#F97583\">?:</span><span style=\"color:#79B8FF\"> string</span><span style=\"color:#6A737D\">   // 文档描述</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  content</span><span style=\"color:#F97583\">:</span><span style=\"color:#79B8FF\"> string</span><span style=\"color:#6A737D\">        // Markdown 内容</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  frontmatter</span><span style=\"color:#F97583\">:</span><span style=\"color:#B392F0\"> Record</span><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#79B8FF\">string</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#79B8FF\">any</span><span style=\"color:#E1E4E8\">>  </span><span style=\"color:#6A737D\">// 前置元数据</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  lastModified</span><span style=\"color:#F97583\">:</span><span style=\"color:#79B8FF\"> number</span><span style=\"color:#6A737D\">   // 最后修改时间戳</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>SiteConfig</h3>\n<p>站点配置对象。</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">interface</span><span style=\"color:#B392F0\"> SiteConfig</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  title</span><span style=\"color:#F97583\">:</span><span style=\"color:#79B8FF\"> string</span><span style=\"color:#6A737D\">          // 站点标题</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  description</span><span style=\"color:#F97583\">:</span><span style=\"color:#79B8FF\"> string</span><span style=\"color:#6A737D\">    // 站点描述</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  baseUrl</span><span style=\"color:#F97583\">:</span><span style=\"color:#79B8FF\"> string</span><span style=\"color:#6A737D\">        // 基础 URL</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  skillsDir</span><span style=\"color:#F97583\">:</span><span style=\"color:#79B8FF\"> string</span><span style=\"color:#6A737D\">      // 源文件目录</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  outputDir</span><span style=\"color:#F97583\">:</span><span style=\"color:#79B8FF\"> string</span><span style=\"color:#6A737D\">      // 输出目录</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>CLI 命令</h2>\n<h3>dev</h3>\n<p>启动开发服务器。</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">docgen</span><span style=\"color:#9ECBFF\"> dev</span><span style=\"color:#E1E4E8\"> [options]</span></span>\n<span class=\"line\"></span></code></pre>\n<p><strong>选项：</strong></p>\n<ul>\n<li><code>--dir &lt;path&gt;</code>: 源文件目录（默认：<code>./docs</code>）</li>\n<li><code>--port &lt;number&gt;</code>: 端口号（默认：<code>3000</code>）</li>\n</ul>\n<h3>build</h3>\n<p>构建静态站点。</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">docgen</span><span style=\"color:#9ECBFF\"> build</span><span style=\"color:#E1E4E8\"> [options]</span></span>\n<span class=\"line\"></span></code></pre>\n<p><strong>选项：</strong></p>\n<ul>\n<li><code>--dir &lt;path&gt;</code>: 源文件目录（默认：<code>./docs</code>）</li>\n<li><code>--output &lt;path&gt;</code>: 输出目录（默认：<code>./dist</code>）</li>\n</ul>\n<h3>preview</h3>\n<p>预览构建后的站点。</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">docgen</span><span style=\"color:#9ECBFF\"> preview</span><span style=\"color:#E1E4E8\"> [options]</span></span>\n<span class=\"line\"></span></code></pre>\n<p><strong>选项：</strong></p>\n<ul>\n<li><code>--output &lt;path&gt;</code>: 站点目录（默认：<code>./dist</code>）</li>\n<li><code>--port &lt;number&gt;</code>: 端口号（默认：<code>4173</code>）</li>\n</ul>\n<h2>错误处理</h2>\n<p>所有异步函数都会抛出错误，建议使用 try-catch 处理：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">try</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">  const</span><span style=\"color:#79B8FF\"> directories</span><span style=\"color:#F97583\"> =</span><span style=\"color:#F97583\"> await</span><span style=\"color:#B392F0\"> scanSkillsDirectory</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'./docs'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">} </span><span style=\"color:#F97583\">catch</span><span style=\"color:#E1E4E8\"> (error) {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  console.</span><span style=\"color:#B392F0\">error</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'扫描失败:'</span><span style=\"color:#E1E4E8\">, error)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>最佳实践</h2>\n<ol>\n<li><strong>使用 TypeScript</strong>：获得完整的类型提示</li>\n<li><strong>错误处理</strong>：始终捕获异步操作的错误</li>\n<li><strong>路径规范</strong>：使用绝对路径避免路径问题</li>\n<li><strong>配置验证</strong>：构建前验证配置对象的完整性</li>\n</ol>\n","headings":[]},"lastModified":1768789238184},{"path":"/Users/pan/docgen/my-docs/api/advanced.md","name":"advanced.md","title":"高级用法","description":"DocGen 高级功能和自定义选项","content":"\n# 高级用法\n\n深入了解 DocGen 的高级功能和自定义选项。\n\n## 自定义主题\n\n### CSS 变量\n\nDocGen 使用 CSS 变量系统，可以轻松自定义主题：\n\n```css\n:root {\n  --color-primary: #0a0a0a;\n  --color-background: #ffffff;\n  --font-sans: -apple-system, sans-serif;\n  --spacing-md: 1rem;\n  --radius-lg: 0.75rem;\n}\n```\n\n### 深色模式\n\n系统自动支持深色模式，基于用户系统偏好：\n\n```css\n@media (prefers-color-scheme: dark) {\n  :root {\n    --color-background: #0a0a0a;\n    --color-foreground: #fafafa;\n  }\n}\n```\n\n## 插件系统\n\n### Vite 插件集成\n\nDocGen 基于 Vite 构建，可以使用任何 Vite 插件：\n\n```typescript\nimport { defineConfig } from 'vite'\nimport vue from '@vitejs/plugin-vue'\nimport markdown from 'vite-plugin-markdown'\n\nexport default defineConfig({\n  plugins: [\n    vue(),\n    markdown()\n  ]\n})\n```\n\n### Markdown-it 扩展\n\n自定义 Markdown 渲染器：\n\n```typescript\nimport MarkdownIt from 'markdown-it'\nimport anchor from 'markdown-it-anchor'\nimport toc from 'markdown-it-toc-done-right'\n\nconst md = new MarkdownIt({\n  html: true,\n  linkify: true,\n  typographer: true\n})\n  .use(anchor)\n  .use(toc)\n```\n\n## 性能优化\n\n### 代码分割\n\n使用动态导入优化加载性能：\n\n```typescript\nconst Home = () => import('./pages/Home.vue')\nconst SkillPage = () => import('./pages/SkillPage.vue')\n```\n\n### 图片优化\n\n建议使用 WebP 格式和响应式图片：\n\n```markdown\n![示例图片](./image.webp)\n```\n\n### 懒加载\n\n对大型文档启用懒加载：\n\n```typescript\nconst observer = new IntersectionObserver((entries) => {\n  entries.forEach(entry => {\n    if (entry.isIntersecting) {\n      // 加载内容\n    }\n  })\n})\n```\n\n## 部署选项\n\n### Netlify\n\n```toml\n[build]\n  command = \"docgen build --dir ./docs --output ./dist\"\n  publish = \"dist\"\n\n[[redirects]]\n  from = \"/*\"\n  to = \"/index.html\"\n  status = 200\n```\n\n### Vercel\n\n```json\n{\n  \"buildCommand\": \"docgen build --dir ./docs --output ./dist\",\n  \"outputDirectory\": \"dist\",\n  \"rewrites\": [\n    { \"source\": \"/(.*)\", \"destination\": \"/index.html\" }\n  ]\n}\n```\n\n### GitHub Pages\n\n```yaml\nname: Deploy\non:\n  push:\n    branches: [main]\njobs:\n  deploy:\n    runs-on: ubuntu-latest\n    steps:\n      - uses: actions/checkout@v2\n      - run: npm install\n      - run: docgen build --dir ./docs --output ./dist\n      - uses: peaceiris/actions-gh-pages@v3\n        with:\n          github_token: ${{ secrets.GITHUB_TOKEN }}\n          publish_dir: ./dist\n```\n\n## 搜索优化\n\n### 全文搜索\n\n实现基于 Fuse.js 的全文搜索：\n\n```typescript\nimport Fuse from 'fuse.js'\n\nconst fuse = new Fuse(files, {\n  keys: ['title', 'content', 'description'],\n  threshold: 0.3\n})\n\nconst results = fuse.search(query)\n```\n\n### SEO 优化\n\n生成 sitemap 和 robots.txt：\n\n```typescript\n// sitemap.xml\nconst urls = files.map(file => ({\n  loc: `${baseUrl}${getFileRoute(file)}`,\n  lastmod: new Date(file.lastModified).toISOString()\n}))\n```\n\n## 国际化\n\n### 多语言支持\n\n组织多语言文档：\n\n```\ndocs/\n  en/\n    getting-started/\n      README.md\n  zh/\n    getting-started/\n      README.md\n```\n\n### 语言切换\n\n```typescript\nconst locale = ref('zh')\n\nfunction switchLocale(newLocale: string) {\n  locale.value = newLocale\n  // 重新加载文档\n}\n```\n\n## 安全性\n\n### 内容安全策略\n\n配置 CSP 头：\n\n```html\n<meta http-equiv=\"Content-Security-Policy\" \n      content=\"default-src 'self'; script-src 'self' 'unsafe-inline'\">\n```\n\n### XSS 防护\n\nMarkdown 渲染时自动转义 HTML：\n\n```typescript\nconst md = new MarkdownIt({\n  html: false  // 禁用原始 HTML\n})\n```\n\n## 监控和分析\n\n### Google Analytics\n\n```html\n<script async src=\"https://www.googletagmanager.com/gtag/js?id=GA_ID\"></script>\n<script>\n  window.dataLayer = window.dataLayer || [];\n  function gtag(){dataLayer.push(arguments);}\n  gtag('js', new Date());\n  gtag('config', 'GA_ID');\n</script>\n```\n\n### 错误追踪\n\n集成 Sentry：\n\n```typescript\nimport * as Sentry from '@sentry/vue'\n\nSentry.init({\n  app,\n  dsn: 'YOUR_DSN',\n  integrations: [new Sentry.BrowserTracing()],\n  tracesSampleRate: 1.0\n})\n```\n","frontmatter":{"title":"高级用法","description":"DocGen 高级功能和自定义选项","html":"<h1>高级用法</h1>\n<p>深入了解 DocGen 的高级功能和自定义选项。</p>\n<h2>自定义主题</h2>\n<h3>CSS 变量</h3>\n<p>DocGen 使用 CSS 变量系统，可以轻松自定义主题：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">:root</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --color-primary</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">#0a0a0a</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --color-background</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">#ffffff</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --font-sans</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">-apple-system</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#79B8FF\">sans-serif</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --spacing-md</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">1</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --radius-lg</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">0.75</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>深色模式</h3>\n<p>系统自动支持深色模式，基于用户系统偏好：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">@media</span><span style=\"color:#E1E4E8\"> (prefers-color-scheme: dark) {</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">  :root</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">    --color-background</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">#0a0a0a</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">    --color-foreground</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">#fafafa</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>插件系统</h2>\n<h3>Vite 插件集成</h3>\n<p>DocGen 基于 Vite 构建，可以使用任何 Vite 插件：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#E1E4E8\"> { defineConfig } </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> 'vite'</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#E1E4E8\"> vue </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> '@vitejs/plugin-vue'</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#E1E4E8\"> markdown </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> 'vite-plugin-markdown'</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#F97583\">export</span><span style=\"color:#F97583\"> default</span><span style=\"color:#B392F0\"> defineConfig</span><span style=\"color:#E1E4E8\">({</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  plugins: [</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">    vue</span><span style=\"color:#E1E4E8\">(),</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">    markdown</span><span style=\"color:#E1E4E8\">()</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  ]</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">})</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>Markdown-it 扩展</h3>\n<p>自定义 Markdown 渲染器：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#E1E4E8\"> MarkdownIt </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> 'markdown-it'</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#E1E4E8\"> anchor </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> 'markdown-it-anchor'</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#E1E4E8\"> toc </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> 'markdown-it-toc-done-right'</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#79B8FF\"> md</span><span style=\"color:#F97583\"> =</span><span style=\"color:#F97583\"> new</span><span style=\"color:#B392F0\"> MarkdownIt</span><span style=\"color:#E1E4E8\">({</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  html: </span><span style=\"color:#79B8FF\">true</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  linkify: </span><span style=\"color:#79B8FF\">true</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  typographer: </span><span style=\"color:#79B8FF\">true</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">})</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  .</span><span style=\"color:#B392F0\">use</span><span style=\"color:#E1E4E8\">(anchor)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  .</span><span style=\"color:#B392F0\">use</span><span style=\"color:#E1E4E8\">(toc)</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>性能优化</h2>\n<h3>代码分割</h3>\n<p>使用动态导入优化加载性能：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#B392F0\"> Home</span><span style=\"color:#F97583\"> =</span><span style=\"color:#E1E4E8\"> () </span><span style=\"color:#F97583\">=></span><span style=\"color:#F97583\"> import</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'./pages/Home.vue'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#B392F0\"> SkillPage</span><span style=\"color:#F97583\"> =</span><span style=\"color:#E1E4E8\"> () </span><span style=\"color:#F97583\">=></span><span style=\"color:#F97583\"> import</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'./pages/SkillPage.vue'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>图片优化</h3>\n<p>建议使用 WebP 格式和响应式图片：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">![</span><span style=\"color:#DBEDFF;text-decoration:underline\">示例图片</span><span style=\"color:#E1E4E8\">](</span><span style=\"color:#E1E4E8;text-decoration:underline\">./image.webp</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>懒加载</h3>\n<p>对大型文档启用懒加载：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#79B8FF\"> observer</span><span style=\"color:#F97583\"> =</span><span style=\"color:#F97583\"> new</span><span style=\"color:#B392F0\"> IntersectionObserver</span><span style=\"color:#E1E4E8\">((</span><span style=\"color:#FFAB70\">entries</span><span style=\"color:#E1E4E8\">) </span><span style=\"color:#F97583\">=></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  entries.</span><span style=\"color:#B392F0\">forEach</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">entry</span><span style=\"color:#F97583\"> =></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">    if</span><span style=\"color:#E1E4E8\"> (entry.isIntersecting) {</span></span>\n<span class=\"line\"><span style=\"color:#6A737D\">      // 加载内容</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  })</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">})</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>部署选项</h2>\n<h3>Netlify</h3>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span>[build]</span></span>\n<span class=\"line\"><span>  command = \"docgen build --dir ./docs --output ./dist\"</span></span>\n<span class=\"line\"><span>  publish = \"dist\"</span></span>\n<span class=\"line\"><span></span></span>\n<span class=\"line\"><span>[[redirects]]</span></span>\n<span class=\"line\"><span>  from = \"/*\"</span></span>\n<span class=\"line\"><span>  to = \"/index.html\"</span></span>\n<span class=\"line\"><span>  status = 200</span></span>\n<span class=\"line\"><span></span></span></code></pre>\n<h3>Vercel</h3>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">{</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  \"buildCommand\"</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">\"docgen build --dir ./docs --output ./dist\"</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  \"outputDirectory\"</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">\"dist\"</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  \"rewrites\"</span><span style=\"color:#E1E4E8\">: [</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    { </span><span style=\"color:#79B8FF\">\"source\"</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">\"/(.*)\"</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#79B8FF\">\"destination\"</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">\"/index.html\"</span><span style=\"color:#E1E4E8\"> }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  ]</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>GitHub Pages</h3>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#85E89D\">name</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">Deploy</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">on</span><span style=\"color:#E1E4E8\">:</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">  push</span><span style=\"color:#E1E4E8\">:</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">    branches</span><span style=\"color:#E1E4E8\">: [</span><span style=\"color:#9ECBFF\">main</span><span style=\"color:#E1E4E8\">]</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">jobs</span><span style=\"color:#E1E4E8\">:</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">  deploy</span><span style=\"color:#E1E4E8\">:</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">    runs-on</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">ubuntu-latest</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">    steps</span><span style=\"color:#E1E4E8\">:</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      - </span><span style=\"color:#85E89D\">uses</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">actions/checkout@v2</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      - </span><span style=\"color:#85E89D\">run</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">npm install</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      - </span><span style=\"color:#85E89D\">run</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">docgen build --dir ./docs --output ./dist</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      - </span><span style=\"color:#85E89D\">uses</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">peaceiris/actions-gh-pages@v3</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">        with</span><span style=\"color:#E1E4E8\">:</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">          github_token</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">${{ secrets.GITHUB_TOKEN }}</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">          publish_dir</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">./dist</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>搜索优化</h2>\n<h3>全文搜索</h3>\n<p>实现基于 Fuse.js 的全文搜索：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#E1E4E8\"> Fuse </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> 'fuse.js'</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#79B8FF\"> fuse</span><span style=\"color:#F97583\"> =</span><span style=\"color:#F97583\"> new</span><span style=\"color:#B392F0\"> Fuse</span><span style=\"color:#E1E4E8\">(files, {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  keys: [</span><span style=\"color:#9ECBFF\">'title'</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#9ECBFF\">'content'</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#9ECBFF\">'description'</span><span style=\"color:#E1E4E8\">],</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  threshold: </span><span style=\"color:#79B8FF\">0.3</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">})</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#79B8FF\"> results</span><span style=\"color:#F97583\"> =</span><span style=\"color:#E1E4E8\"> fuse.</span><span style=\"color:#B392F0\">search</span><span style=\"color:#E1E4E8\">(query)</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>SEO 优化</h3>\n<p>生成 sitemap 和 robots.txt：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#6A737D\">// sitemap.xml</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#79B8FF\"> urls</span><span style=\"color:#F97583\"> =</span><span style=\"color:#E1E4E8\"> files.</span><span style=\"color:#B392F0\">map</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">file</span><span style=\"color:#F97583\"> =></span><span style=\"color:#E1E4E8\"> ({</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  loc: </span><span style=\"color:#9ECBFF\">`${</span><span style=\"color:#E1E4E8\">baseUrl</span><span style=\"color:#9ECBFF\">}${</span><span style=\"color:#B392F0\">getFileRoute</span><span style=\"color:#9ECBFF\">(</span><span style=\"color:#E1E4E8\">file</span><span style=\"color:#9ECBFF\">)</span><span style=\"color:#9ECBFF\">}`</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  lastmod: </span><span style=\"color:#F97583\">new</span><span style=\"color:#B392F0\"> Date</span><span style=\"color:#E1E4E8\">(file.lastModified).</span><span style=\"color:#B392F0\">toISOString</span><span style=\"color:#E1E4E8\">()</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}))</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>国际化</h2>\n<h3>多语言支持</h3>\n<p>组织多语言文档：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span>docs/</span></span>\n<span class=\"line\"><span>  en/</span></span>\n<span class=\"line\"><span>    getting-started/</span></span>\n<span class=\"line\"><span>      README.md</span></span>\n<span class=\"line\"><span>  zh/</span></span>\n<span class=\"line\"><span>    getting-started/</span></span>\n<span class=\"line\"><span>      README.md</span></span>\n<span class=\"line\"><span></span></span></code></pre>\n<h3>语言切换</h3>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#79B8FF\"> locale</span><span style=\"color:#F97583\"> =</span><span style=\"color:#B392F0\"> ref</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'zh'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#F97583\">function</span><span style=\"color:#B392F0\"> switchLocale</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">newLocale</span><span style=\"color:#F97583\">:</span><span style=\"color:#79B8FF\"> string</span><span style=\"color:#E1E4E8\">) {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  locale.value </span><span style=\"color:#F97583\">=</span><span style=\"color:#E1E4E8\"> newLocale</span></span>\n<span class=\"line\"><span style=\"color:#6A737D\">  // 重新加载文档</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>安全性</h2>\n<h3>内容安全策略</h3>\n<p>配置 CSP 头：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">meta</span><span style=\"color:#B392F0\"> http-equiv</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"Content-Security-Policy\"</span><span style=\"color:#E1E4E8\"> </span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">      content</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"default-src 'self'; script-src 'self' 'unsafe-inline'\"</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span></code></pre>\n<h3>XSS 防护</h3>\n<p>Markdown 渲染时自动转义 HTML：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#79B8FF\"> md</span><span style=\"color:#F97583\"> =</span><span style=\"color:#F97583\"> new</span><span style=\"color:#B392F0\"> MarkdownIt</span><span style=\"color:#E1E4E8\">({</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  html: </span><span style=\"color:#79B8FF\">false</span><span style=\"color:#6A737D\">  // 禁用原始 HTML</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">})</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>监控和分析</h2>\n<h3>Google Analytics</h3>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">script</span><span style=\"color:#B392F0\"> async</span><span style=\"color:#B392F0\"> src</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"https://www.googletagmanager.com/gtag/js?id=GA_ID\"</span><span style=\"color:#E1E4E8\">>&#x3C;/</span><span style=\"color:#85E89D\">script</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">script</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  window.dataLayer </span><span style=\"color:#F97583\">=</span><span style=\"color:#E1E4E8\"> window.dataLayer </span><span style=\"color:#F97583\">||</span><span style=\"color:#E1E4E8\"> [];</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">  function</span><span style=\"color:#B392F0\"> gtag</span><span style=\"color:#E1E4E8\">(){dataLayer.</span><span style=\"color:#B392F0\">push</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#79B8FF\">arguments</span><span style=\"color:#E1E4E8\">);}</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">  gtag</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'js'</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#F97583\">new</span><span style=\"color:#B392F0\"> Date</span><span style=\"color:#E1E4E8\">());</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">  gtag</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'config'</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#9ECBFF\">'GA_ID'</span><span style=\"color:#E1E4E8\">);</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;/</span><span style=\"color:#85E89D\">script</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span></code></pre>\n<h3>错误追踪</h3>\n<p>集成 Sentry：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#79B8FF\"> *</span><span style=\"color:#F97583\"> as</span><span style=\"color:#E1E4E8\"> Sentry </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> '@sentry/vue'</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">Sentry.</span><span style=\"color:#B392F0\">init</span><span style=\"color:#E1E4E8\">({</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  app,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  dsn: </span><span style=\"color:#9ECBFF\">'YOUR_DSN'</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  integrations: [</span><span style=\"color:#F97583\">new</span><span style=\"color:#E1E4E8\"> Sentry.</span><span style=\"color:#B392F0\">BrowserTracing</span><span style=\"color:#E1E4E8\">()],</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  tracesSampleRate: </span><span style=\"color:#79B8FF\">1.0</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">})</span></span>\n<span class=\"line\"></span></code></pre>\n","headings":[]},"lastModified":1768789263861},{"path":"/Users/pan/docgen/my-docs/getting-started/README.md","name":"README.md","title":"快速开始","description":"DocGen 快速入门指南","content":"\n# 快速开始\n\n欢迎使用 DocGen！这是一个用于生成文档网站的工具。\n\n## 安装\n\n```bash\nnpm install -g docgen\n```\n\n## 基本使用\n\n创建你的文档目录结构，然后运行：\n\n```bash\ndocgen dev --dir ./my-docs\n```\n\n就这么简单！\n","frontmatter":{"title":"快速开始","description":"DocGen 快速入门指南","html":"<h1>快速开始</h1>\n<p>欢迎使用 DocGen！这是一个用于生成文档网站的工具。</p>\n<h2>安装</h2>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">npm</span><span style=\"color:#9ECBFF\"> install</span><span style=\"color:#79B8FF\"> -g</span><span style=\"color:#9ECBFF\"> docgen</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>基本使用</h2>\n<p>创建你的文档目录结构，然后运行：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">docgen</span><span style=\"color:#9ECBFF\"> dev</span><span style=\"color:#79B8FF\"> --dir</span><span style=\"color:#9ECBFF\"> ./my-docs</span></span>\n<span class=\"line\"></span></code></pre>\n<p>就这么简单！</p>\n","headings":[]},"lastModified":1768787451416},{"path":"/Users/pan/docgen/my-docs/tutorials/README.md","name":"README.md","title":"教程指南","description":"从零开始学习使用 DocGen","content":"\n# 教程指南\n\n通过实际示例学习如何使用 DocGen 构建文档站点。\n\n## 第一步：创建项目\n\n### 1. 安装 DocGen\n\n首先安装 DocGen CLI 工具：\n\n```bash\nnpm install -g docgen\n```\n\n验证安装：\n\n```bash\ndocgen --version\n```\n\n### 2. 创建文档目录\n\n创建你的文档项目结构：\n\n```bash\nmkdir my-documentation\ncd my-documentation\nmkdir docs\n```\n\n### 3. 编写第一个文档\n\n创建 `docs/getting-started/README.md`：\n\n```markdown\n---\ntitle: 快速开始\ndescription: 开始使用我们的产品\n---\n\n# 快速开始\n\n欢迎使用我们的产品！\n\n## 安装\n\n\\`\\`\\`bash\nnpm install my-product\n\\`\\`\\`\n\n## 基本用法\n\n\\`\\`\\`javascript\nimport { MyProduct } from 'my-product'\n\nconst product = new MyProduct()\nproduct.start()\n\\`\\`\\`\n```\n\n## 第二步：启动开发服务器\n\n### 实时预览\n\n启动开发服务器查看效果：\n\n```bash\ndocgen dev --dir ./docs\n```\n\n访问 `http://localhost:3000` 查看你的文档站点。\n\n### 热更新\n\n修改任何 Markdown 文件，浏览器会自动刷新显示最新内容。\n\n### 调试技巧\n\n1. **检查控制台**：打开浏览器开发者工具查看错误\n2. **验证路径**：确保文件路径正确\n3. **清理缓存**：遇到问题时清理 `node_modules/.vite`\n\n## 第三步：组织文档结构\n\n### 推荐目录结构\n\n```\ndocs/\n├── getting-started/\n│   ├── README.md\n│   ├── installation.md\n│   └── quick-start.md\n├── guides/\n│   ├── README.md\n│   ├── basic-usage.md\n│   └── advanced-features.md\n├── api/\n│   ├── README.md\n│   ├── core-api.md\n│   └── utilities.md\n└── faq/\n    └── README.md\n```\n\n### 文件命名规范\n\n- 使用小写字母和连字符\n- `README.md` 作为目录首页\n- 描述性文件名：`user-authentication.md`\n\n### Frontmatter 最佳实践\n\n每个文档都应包含 frontmatter：\n\n```yaml\n---\ntitle: 页面标题\ndescription: 页面描述（用于 SEO）\nauthor: 作者名称\ndate: 2026-01-19\ntags: [tutorial, beginner]\n---\n```\n\n## 第四步：添加代码示例\n\n### 语法高亮\n\n使用语言标识符启用语法高亮：\n\n````markdown\n```javascript\nfunction hello() {\n  console.log('Hello, World!')\n}\n```\n\n```python\ndef hello():\n    print(\"Hello, World!\")\n```\n\n```bash\necho \"Hello, World!\"\n```\n````\n\n### 代码注释\n\n添加注释说明关键代码：\n\n```javascript\n// 初始化应用\nconst app = createApp()\n\n// 配置路由\napp.use(router)\n\n// 启动应用\napp.mount('#app')\n```\n\n### 可运行示例\n\n提供完整的可运行代码：\n\n```javascript\n// 完整示例：用户认证\nimport { authenticate } from './auth'\n\nasync function login(username, password) {\n  try {\n    const user = await authenticate(username, password)\n    console.log('登录成功:', user)\n    return user\n  } catch (error) {\n    console.error('登录失败:', error)\n    throw error\n  }\n}\n\n// 使用示例\nlogin('user@example.com', 'password123')\n```\n\n## 第五步：构建生产版本\n\n### 构建站点\n\n生成静态文件：\n\n```bash\ndocgen build --dir ./docs --output ./dist\n```\n\n### 验证构建\n\n预览构建后的站点：\n\n```bash\ndocgen preview --output ./dist\n```\n\n### 优化建议\n\n1. **压缩图片**：使用 WebP 格式\n2. **代码分割**：大型文档分成多个文件\n3. **缓存策略**：配置适当的缓存头\n\n## 第六步：部署上线\n\n### 部署到 Netlify\n\n1. 连接 Git 仓库\n2. 配置构建命令：`docgen build --dir ./docs --output ./dist`\n3. 设置发布目录：`dist`\n4. 点击部署\n\n### 部署到 Vercel\n\n```bash\nnpm install -g vercel\nvercel --prod\n```\n\n### 自定义域名\n\n在部署平台配置自定义域名：\n\n1. 添加 CNAME 记录\n2. 配置 SSL 证书\n3. 等待 DNS 生效\n\n## 常见问题\n\n### 样式不显示？\n\n清理缓存并重新构建：\n\n```bash\nrm -rf node_modules/.vite\ndocgen build --dir ./docs --output ./dist\n```\n\n### 路由 404 错误？\n\n确保服务器配置了 SPA 回退：\n\n```nginx\nlocation / {\n  try_files $uri $uri/ /index.html;\n}\n```\n\n### 搜索不工作？\n\n检查文件是否正确扫描：\n\n```bash\ndocgen build --dir ./docs --output ./dist --verbose\n```\n\n## 下一步\n\n- 阅读 [API 参考](../api/README.md)\n- 查看 [配置选项](../configuration/README.md)\n- 浏览 [FAQ](../faq/README.md)\n","frontmatter":{"title":"教程指南","description":"从零开始学习使用 DocGen","html":"<h1>教程指南</h1>\n<p>通过实际示例学习如何使用 DocGen 构建文档站点。</p>\n<h2>第一步：创建项目</h2>\n<h3>1. 安装 DocGen</h3>\n<p>首先安装 DocGen CLI 工具：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">npm</span><span style=\"color:#9ECBFF\"> install</span><span style=\"color:#79B8FF\"> -g</span><span style=\"color:#9ECBFF\"> docgen</span></span>\n<span class=\"line\"></span></code></pre>\n<p>验证安装：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">docgen</span><span style=\"color:#79B8FF\"> --version</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>2. 创建文档目录</h3>\n<p>创建你的文档项目结构：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">mkdir</span><span style=\"color:#9ECBFF\"> my-documentation</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">cd</span><span style=\"color:#9ECBFF\"> my-documentation</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">mkdir</span><span style=\"color:#9ECBFF\"> docs</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>3. 编写第一个文档</h3>\n<p>创建 <code>docs/getting-started/README.md</code>：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">---</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">title</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">快速开始</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">description</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">开始使用我们的产品</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">---</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#79B8FF;font-weight:bold\"># 快速开始</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">欢迎使用我们的产品！</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#79B8FF;font-weight:bold\">## 安装</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">\\`\\`\\`</span><span style=\"color:#E1E4E8\">bash</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">npm install my-product</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">\\`\\`\\`</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#79B8FF;font-weight:bold\">## 基本用法</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">\\`\\`\\`</span><span style=\"color:#E1E4E8\">javascript</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">import { MyProduct } from 'my-product'</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">const product = new MyProduct()</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">product.start()</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">\\`\\`\\`</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>第二步：启动开发服务器</h2>\n<h3>实时预览</h3>\n<p>启动开发服务器查看效果：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">docgen</span><span style=\"color:#9ECBFF\"> dev</span><span style=\"color:#79B8FF\"> --dir</span><span style=\"color:#9ECBFF\"> ./docs</span></span>\n<span class=\"line\"></span></code></pre>\n<p>访问 <code>http://localhost:3000</code> 查看你的文档站点。</p>\n<h3>热更新</h3>\n<p>修改任何 Markdown 文件，浏览器会自动刷新显示最新内容。</p>\n<h3>调试技巧</h3>\n<ol>\n<li><strong>检查控制台</strong>：打开浏览器开发者工具查看错误</li>\n<li><strong>验证路径</strong>：确保文件路径正确</li>\n<li><strong>清理缓存</strong>：遇到问题时清理 <code>node_modules/.vite</code></li>\n</ol>\n<h2>第三步：组织文档结构</h2>\n<h3>推荐目录结构</h3>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span>docs/</span></span>\n<span class=\"line\"><span>├── getting-started/</span></span>\n<span class=\"line\"><span>│   ├── README.md</span></span>\n<span class=\"line\"><span>│   ├── installation.md</span></span>\n<span class=\"line\"><span>│   └── quick-start.md</span></span>\n<span class=\"line\"><span>├── guides/</span></span>\n<span class=\"line\"><span>│   ├── README.md</span></span>\n<span class=\"line\"><span>│   ├── basic-usage.md</span></span>\n<span class=\"line\"><span>│   └── advanced-features.md</span></span>\n<span class=\"line\"><span>├── api/</span></span>\n<span class=\"line\"><span>│   ├── README.md</span></span>\n<span class=\"line\"><span>│   ├── core-api.md</span></span>\n<span class=\"line\"><span>│   └── utilities.md</span></span>\n<span class=\"line\"><span>└── faq/</span></span>\n<span class=\"line\"><span>    └── README.md</span></span>\n<span class=\"line\"><span></span></span></code></pre>\n<h3>文件命名规范</h3>\n<ul>\n<li>使用小写字母和连字符</li>\n<li><code>README.md</code> 作为目录首页</li>\n<li>描述性文件名：<code>user-authentication.md</code></li>\n</ul>\n<h3>Frontmatter 最佳实践</h3>\n<p>每个文档都应包含 frontmatter：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">---</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">title</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">页面标题</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">description</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">页面描述（用于 SEO）</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">author</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">作者名称</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">date</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">2026-01-19</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">tags</span><span style=\"color:#E1E4E8\">: [</span><span style=\"color:#9ECBFF\">tutorial</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#9ECBFF\">beginner</span><span style=\"color:#E1E4E8\">]</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">---</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>第四步：添加代码示例</h2>\n<h3>语法高亮</h3>\n<p>使用语言标识符启用语法高亮：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">```javascript</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">function</span><span style=\"color:#B392F0\"> hello</span><span style=\"color:#E1E4E8\">() {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  console.</span><span style=\"color:#B392F0\">log</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'Hello, World!'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">```</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">```python</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">def</span><span style=\"color:#B392F0\"> hello</span><span style=\"color:#E1E4E8\">():</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">    print</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">\"Hello, World!\"</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">```</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">```bash</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">echo</span><span style=\"color:#9ECBFF\"> \"Hello, World!\"</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">```</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>代码注释</h3>\n<p>添加注释说明关键代码：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#6A737D\">// 初始化应用</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#79B8FF\"> app</span><span style=\"color:#F97583\"> =</span><span style=\"color:#B392F0\"> createApp</span><span style=\"color:#E1E4E8\">()</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#6A737D\">// 配置路由</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">app.</span><span style=\"color:#B392F0\">use</span><span style=\"color:#E1E4E8\">(router)</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#6A737D\">// 启动应用</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">app.</span><span style=\"color:#B392F0\">mount</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'#app'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>可运行示例</h3>\n<p>提供完整的可运行代码：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#6A737D\">// 完整示例：用户认证</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#E1E4E8\"> { authenticate } </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> './auth'</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#F97583\">async</span><span style=\"color:#F97583\"> function</span><span style=\"color:#B392F0\"> login</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">username</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#FFAB70\">password</span><span style=\"color:#E1E4E8\">) {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">  try</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">    const</span><span style=\"color:#79B8FF\"> user</span><span style=\"color:#F97583\"> =</span><span style=\"color:#F97583\"> await</span><span style=\"color:#B392F0\"> authenticate</span><span style=\"color:#E1E4E8\">(username, password)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    console.</span><span style=\"color:#B392F0\">log</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'登录成功:'</span><span style=\"color:#E1E4E8\">, user)</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">    return</span><span style=\"color:#E1E4E8\"> user</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  } </span><span style=\"color:#F97583\">catch</span><span style=\"color:#E1E4E8\"> (error) {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    console.</span><span style=\"color:#B392F0\">error</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'登录失败:'</span><span style=\"color:#E1E4E8\">, error)</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">    throw</span><span style=\"color:#E1E4E8\"> error</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#6A737D\">// 使用示例</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">login</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'user@example.com'</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#9ECBFF\">'password123'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>第五步：构建生产版本</h2>\n<h3>构建站点</h3>\n<p>生成静态文件：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">docgen</span><span style=\"color:#9ECBFF\"> build</span><span style=\"color:#79B8FF\"> --dir</span><span style=\"color:#9ECBFF\"> ./docs</span><span style=\"color:#79B8FF\"> --output</span><span style=\"color:#9ECBFF\"> ./dist</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>验证构建</h3>\n<p>预览构建后的站点：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">docgen</span><span style=\"color:#9ECBFF\"> preview</span><span style=\"color:#79B8FF\"> --output</span><span style=\"color:#9ECBFF\"> ./dist</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>优化建议</h3>\n<ol>\n<li><strong>压缩图片</strong>：使用 WebP 格式</li>\n<li><strong>代码分割</strong>：大型文档分成多个文件</li>\n<li><strong>缓存策略</strong>：配置适当的缓存头</li>\n</ol>\n<h2>第六步：部署上线</h2>\n<h3>部署到 Netlify</h3>\n<ol>\n<li>连接 Git 仓库</li>\n<li>配置构建命令：<code>docgen build --dir ./docs --output ./dist</code></li>\n<li>设置发布目录：<code>dist</code></li>\n<li>点击部署</li>\n</ol>\n<h3>部署到 Vercel</h3>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">npm</span><span style=\"color:#9ECBFF\"> install</span><span style=\"color:#79B8FF\"> -g</span><span style=\"color:#9ECBFF\"> vercel</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">vercel</span><span style=\"color:#79B8FF\"> --prod</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>自定义域名</h3>\n<p>在部署平台配置自定义域名：</p>\n<ol>\n<li>添加 CNAME 记录</li>\n<li>配置 SSL 证书</li>\n<li>等待 DNS 生效</li>\n</ol>\n<h2>常见问题</h2>\n<h3>样式不显示？</h3>\n<p>清理缓存并重新构建：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">rm</span><span style=\"color:#79B8FF\"> -rf</span><span style=\"color:#9ECBFF\"> node_modules/.vite</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">docgen</span><span style=\"color:#9ECBFF\"> build</span><span style=\"color:#79B8FF\"> --dir</span><span style=\"color:#9ECBFF\"> ./docs</span><span style=\"color:#79B8FF\"> --output</span><span style=\"color:#9ECBFF\"> ./dist</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>路由 404 错误？</h3>\n<p>确保服务器配置了 SPA 回退：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span>location / {</span></span>\n<span class=\"line\"><span>  try_files $uri $uri/ /index.html;</span></span>\n<span class=\"line\"><span>}</span></span>\n<span class=\"line\"><span></span></span></code></pre>\n<h3>搜索不工作？</h3>\n<p>检查文件是否正确扫描：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">docgen</span><span style=\"color:#9ECBFF\"> build</span><span style=\"color:#79B8FF\"> --dir</span><span style=\"color:#9ECBFF\"> ./docs</span><span style=\"color:#79B8FF\"> --output</span><span style=\"color:#9ECBFF\"> ./dist</span><span style=\"color:#79B8FF\"> --verbose</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>下一步</h2>\n<ul>\n<li>阅读 <a href=\"../api/README.md\">API 参考</a></li>\n<li>查看 <a href=\"../configuration/README.md\">配置选项</a></li>\n<li>浏览 <a href=\"../faq/README.md\">FAQ</a></li>\n</ul>\n","headings":[]},"lastModified":1768789292382},{"path":"/Users/pan/docgen/my-docs/tutorials/customization.md","name":"customization.md","title":"自定义文档站点","description":"学习如何自定义 DocGen 文档站点的外观和功能","content":"\n# 自定义文档站点\n\n让你的文档站点与众不同。\n\n## 自定义样式\n\n### 修改颜色主题\n\n创建自定义 CSS 文件覆盖默认变量：\n\n```css\n/* custom.css */\n:root {\n  /* 主色调 */\n  --color-primary: #3b82f6;\n  --color-primary-foreground: #ffffff;\n  \n  /* 背景色 */\n  --color-background: #f9fafb;\n  --color-foreground: #111827;\n  \n  /* 强调色 */\n  --color-accent: #dbeafe;\n  --color-accent-foreground: #1e40af;\n  \n  /* 边框和分隔线 */\n  --color-border: #e5e7eb;\n  --color-muted: #f3f4f6;\n}\n```\n\n### 自定义字体\n\n使用 Google Fonts 或本地字体：\n\n```css\n@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');\n\n:root {\n  --font-sans: 'Inter', -apple-system, sans-serif;\n  --font-mono: 'Fira Code', monospace;\n}\n\nbody {\n  font-family: var(--font-sans);\n}\n\ncode, pre {\n  font-family: var(--font-mono);\n}\n```\n\n### 响应式断点\n\n自定义移动端和桌面端样式：\n\n```css\n/* 移动端 */\n@media (max-width: 768px) {\n  .container {\n    padding: 0 1rem;\n  }\n  \n  .sidebar {\n    transform: translateX(-100%);\n  }\n}\n\n/* 平板 */\n@media (min-width: 769px) and (max-width: 1024px) {\n  .container {\n    max-width: 720px;\n  }\n}\n\n/* 桌面端 */\n@media (min-width: 1025px) {\n  .container {\n    max-width: 1200px;\n  }\n}\n```\n\n## 自定义组件\n\n### 添加自定义 Logo\n\n替换默认 Logo：\n\n```html\n<!-- 在 index.html 中 -->\n<div class=\"logo\">\n  <img src=\"/logo.svg\" alt=\"My Docs\" />\n  <span>My Documentation</span>\n</div>\n```\n\n### 自定义导航栏\n\n添加额外的导航链接：\n\n```vue\n<template>\n  <header class=\"header\">\n    <nav class=\"nav\">\n      <a href=\"/\">首页</a>\n      <a href=\"/docs\">文档</a>\n      <a href=\"/blog\">博客</a>\n      <a href=\"/about\">关于</a>\n    </nav>\n  </header>\n</template>\n```\n\n### 添加页脚\n\n创建自定义页脚组件：\n\n```vue\n<template>\n  <footer class=\"footer\">\n    <div class=\"footer-content\">\n      <div class=\"footer-section\">\n        <h3>产品</h3>\n        <ul>\n          <li><a href=\"/features\">功能特性</a></li>\n          <li><a href=\"/pricing\">价格方案</a></li>\n          <li><a href=\"/roadmap\">产品路线图</a></li>\n        </ul>\n      </div>\n      \n      <div class=\"footer-section\">\n        <h3>资源</h3>\n        <ul>\n          <li><a href=\"/docs\">文档</a></li>\n          <li><a href=\"/api\">API 参考</a></li>\n          <li><a href=\"/examples\">示例代码</a></li>\n        </ul>\n      </div>\n      \n      <div class=\"footer-section\">\n        <h3>社区</h3>\n        <ul>\n          <li><a href=\"/blog\">博客</a></li>\n          <li><a href=\"/forum\">论坛</a></li>\n          <li><a href=\"/discord\">Discord</a></li>\n        </ul>\n      </div>\n    </div>\n    \n    <div class=\"footer-bottom\">\n      <p>&copy; 2026 Your Company. All rights reserved.</p>\n    </div>\n  </footer>\n</template>\n\n<style scoped>\n.footer {\n  background: var(--color-muted);\n  border-top: 1px solid var(--color-border);\n  padding: 3rem 0 1rem;\n  margin-top: 4rem;\n}\n\n.footer-content {\n  display: grid;\n  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));\n  gap: 2rem;\n  max-width: 1200px;\n  margin: 0 auto;\n  padding: 0 2rem;\n}\n\n.footer-section h3 {\n  font-size: 0.875rem;\n  font-weight: 600;\n  margin-bottom: 1rem;\n  text-transform: uppercase;\n  letter-spacing: 0.05em;\n}\n\n.footer-section ul {\n  list-style: none;\n  padding: 0;\n}\n\n.footer-section li {\n  margin-bottom: 0.5rem;\n}\n\n.footer-section a {\n  color: var(--color-muted-foreground);\n  text-decoration: none;\n  font-size: 0.875rem;\n}\n\n.footer-section a:hover {\n  color: var(--color-primary);\n}\n\n.footer-bottom {\n  text-align: center;\n  margin-top: 2rem;\n  padding-top: 2rem;\n  border-top: 1px solid var(--color-border);\n  color: var(--color-muted-foreground);\n  font-size: 0.875rem;\n}\n</style>\n```\n\n## 自定义 Markdown 渲染\n\n### 添加自定义容器\n\n支持警告、提示等容器：\n\n```markdown\n::: warning\n这是一个警告信息\n:::\n\n::: tip\n这是一个提示信息\n:::\n\n::: danger\n这是一个危险警告\n:::\n```\n\n实现自定义容器：\n\n```typescript\nimport MarkdownIt from 'markdown-it'\nimport container from 'markdown-it-container'\n\nconst md = new MarkdownIt()\n  .use(container, 'warning', {\n    render: (tokens, idx) => {\n      if (tokens[idx].nesting === 1) {\n        return '<div class=\"warning\">\\n'\n      } else {\n        return '</div>\\n'\n      }\n    }\n  })\n  .use(container, 'tip', {\n    render: (tokens, idx) => {\n      if (tokens[idx].nesting === 1) {\n        return '<div class=\"tip\">\\n'\n      } else {\n        return '</div>\\n'\n      }\n    }\n  })\n```\n\n### 代码块增强\n\n添加复制按钮和行号：\n\n```typescript\nmd.renderer.rules.fence = (tokens, idx) => {\n  const token = tokens[idx]\n  const lang = token.info.trim()\n  const code = token.content\n  \n  return `\n    <div class=\"code-block\">\n      <div class=\"code-header\">\n        <span class=\"language\">${lang}</span>\n        <button class=\"copy-button\" onclick=\"copyCode(this)\">\n          复制\n        </button>\n      </div>\n      <pre><code class=\"language-${lang}\">${escapeHtml(code)}</code></pre>\n    </div>\n  `\n}\n```\n\n### 自动链接标题\n\n为所有标题添加锚点链接：\n\n```typescript\nimport anchor from 'markdown-it-anchor'\n\nmd.use(anchor, {\n  permalink: true,\n  permalinkBefore: true,\n  permalinkSymbol: '#',\n  permalinkClass: 'header-anchor'\n})\n```\n\n## 添加交互功能\n\n### 代码复制功能\n\n```javascript\nfunction copyCode(button) {\n  const codeBlock = button.closest('.code-block')\n  const code = codeBlock.querySelector('code').textContent\n  \n  navigator.clipboard.writeText(code).then(() => {\n    button.textContent = '已复制!'\n    setTimeout(() => {\n      button.textContent = '复制'\n    }, 2000)\n  })\n}\n```\n\n### 目录高亮\n\n滚动时高亮当前章节：\n\n```javascript\nconst observer = new IntersectionObserver((entries) => {\n  entries.forEach(entry => {\n    if (entry.isIntersecting) {\n      const id = entry.target.id\n      document.querySelectorAll('.toc-link').forEach(link => {\n        link.classList.remove('active')\n      })\n      document.querySelector(`a[href=\"#${id}\"]`)?.classList.add('active')\n    }\n  })\n}, {\n  rootMargin: '-100px 0px -80% 0px'\n})\n\ndocument.querySelectorAll('h2, h3').forEach(heading => {\n  observer.observe(heading)\n})\n```\n\n### 深色模式切换\n\n添加手动切换深色模式：\n\n```vue\n<template>\n  <button @click=\"toggleDarkMode\" class=\"theme-toggle\">\n    <span v-if=\"isDark\">🌞</span>\n    <span v-else>🌙</span>\n  </button>\n</template>\n\n<script setup>\nimport { ref, onMounted } from 'vue'\n\nconst isDark = ref(false)\n\nonMounted(() => {\n  isDark.value = localStorage.getItem('theme') === 'dark'\n  applyTheme()\n})\n\nfunction toggleDarkMode() {\n  isDark.value = !isDark.value\n  localStorage.setItem('theme', isDark.value ? 'dark' : 'light')\n  applyTheme()\n}\n\nfunction applyTheme() {\n  if (isDark.value) {\n    document.documentElement.classList.add('dark')\n  } else {\n    document.documentElement.classList.remove('dark')\n  }\n}\n</script>\n```\n\n## 集成第三方服务\n\n### 添加评论系统\n\n使用 Giscus：\n\n```html\n<script src=\"https://giscus.app/client.js\"\n        data-repo=\"your-username/your-repo\"\n        data-repo-id=\"your-repo-id\"\n        data-category=\"Announcements\"\n        data-category-id=\"your-category-id\"\n        data-mapping=\"pathname\"\n        data-reactions-enabled=\"1\"\n        data-emit-metadata=\"0\"\n        data-input-position=\"bottom\"\n        data-theme=\"light\"\n        data-lang=\"zh-CN\"\n        crossorigin=\"anonymous\"\n        async>\n</script>\n```\n\n### 添加搜索功能\n\n集成 Algolia DocSearch：\n\n```html\n<link rel=\"stylesheet\" href=\"https://cdn.jsdelivr.net/npm/@docsearch/css@3\" />\n\n<script src=\"https://cdn.jsdelivr.net/npm/@docsearch/js@3\"></script>\n<script>\n  docsearch({\n    appId: 'YOUR_APP_ID',\n    apiKey: 'YOUR_API_KEY',\n    indexName: 'YOUR_INDEX_NAME',\n    container: '#docsearch',\n  })\n</script>\n```\n\n### 添加分析统计\n\nGoogle Analytics 4：\n\n```html\n<script async src=\"https://www.googletagmanager.com/gtag/js?id=G-XXXXXXXXXX\"></script>\n<script>\n  window.dataLayer = window.dataLayer || [];\n  function gtag(){dataLayer.push(arguments);}\n  gtag('js', new Date());\n  gtag('config', 'G-XXXXXXXXXX');\n</script>\n```\n\n## 性能优化\n\n### 图片懒加载\n\n```html\n<img src=\"placeholder.jpg\" \n     data-src=\"actual-image.jpg\" \n     loading=\"lazy\" \n     alt=\"描述\">\n```\n\n### 预加载关键资源\n\n```html\n<link rel=\"preload\" href=\"/fonts/inter.woff2\" as=\"font\" type=\"font/woff2\" crossorigin>\n<link rel=\"preload\" href=\"/critical.css\" as=\"style\">\n```\n\n### Service Worker 缓存\n\n```javascript\n// service-worker.js\nself.addEventListener('install', (event) => {\n  event.waitUntil(\n    caches.open('docs-v1').then((cache) => {\n      return cache.addAll([\n        '/',\n        '/index.html',\n        '/assets/main.css',\n        '/assets/main.js'\n      ])\n    })\n  )\n})\n\nself.addEventListener('fetch', (event) => {\n  event.respondWith(\n    caches.match(event.request).then((response) => {\n      return response || fetch(event.request)\n    })\n  )\n})\n```\n\n## 总结\n\n通过这些自定义选项，你可以：\n\n- ✅ 创建独特的视觉风格\n- ✅ 添加自定义功能组件\n- ✅ 增强 Markdown 渲染\n- ✅ 集成第三方服务\n- ✅ 优化性能和用户体验\n\n继续探索更多可能性！\n","frontmatter":{"title":"自定义文档站点","description":"学习如何自定义 DocGen 文档站点的外观和功能","html":"<h1>自定义文档站点</h1>\n<p>让你的文档站点与众不同。</p>\n<h2>自定义样式</h2>\n<h3>修改颜色主题</h3>\n<p>创建自定义 CSS 文件覆盖默认变量：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#6A737D\">/* custom.css */</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">:root</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#6A737D\">  /* 主色调 */</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --color-primary</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">#3b82f6</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --color-primary-foreground</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">#ffffff</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  </span></span>\n<span class=\"line\"><span style=\"color:#6A737D\">  /* 背景色 */</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --color-background</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">#f9fafb</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --color-foreground</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">#111827</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  </span></span>\n<span class=\"line\"><span style=\"color:#6A737D\">  /* 强调色 */</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --color-accent</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">#dbeafe</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --color-accent-foreground</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">#1e40af</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  </span></span>\n<span class=\"line\"><span style=\"color:#6A737D\">  /* 边框和分隔线 */</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --color-border</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">#e5e7eb</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --color-muted</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">#f3f4f6</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>自定义字体</h3>\n<p>使用 Google Fonts 或本地字体：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">@import</span><span style=\"color:#79B8FF\"> url</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&#x26;display=swap'</span><span style=\"color:#E1E4E8\">);</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#B392F0\">:root</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --font-sans</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">'Inter'</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#79B8FF\">-apple-system</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#79B8FF\">sans-serif</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --font-mono</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">'Fira Code'</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#79B8FF\">monospace</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#85E89D\">body</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  font-family</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">var</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">--font-sans</span><span style=\"color:#E1E4E8\">);</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#85E89D\">code</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#85E89D\">pre</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  font-family</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">var</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">--font-mono</span><span style=\"color:#E1E4E8\">);</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>响应式断点</h3>\n<p>自定义移动端和桌面端样式：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#6A737D\">/* 移动端 */</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">@media</span><span style=\"color:#E1E4E8\"> (</span><span style=\"color:#79B8FF\">max-width</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">768</span><span style=\"color:#F97583\">px</span><span style=\"color:#E1E4E8\">) {</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">  .container</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">    padding</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">0</span><span style=\"color:#79B8FF\"> 1</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  </span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">  .sidebar</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">    transform</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">translateX</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#79B8FF\">-100</span><span style=\"color:#F97583\">%</span><span style=\"color:#E1E4E8\">);</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#6A737D\">/* 平板 */</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">@media</span><span style=\"color:#E1E4E8\"> (</span><span style=\"color:#79B8FF\">min-width</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">769</span><span style=\"color:#F97583\">px</span><span style=\"color:#E1E4E8\">) </span><span style=\"color:#F97583\">and</span><span style=\"color:#E1E4E8\"> (</span><span style=\"color:#79B8FF\">max-width</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">1024</span><span style=\"color:#F97583\">px</span><span style=\"color:#E1E4E8\">) {</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">  .container</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">    max-width</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">720</span><span style=\"color:#F97583\">px</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#6A737D\">/* 桌面端 */</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">@media</span><span style=\"color:#E1E4E8\"> (</span><span style=\"color:#79B8FF\">min-width</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">1025</span><span style=\"color:#F97583\">px</span><span style=\"color:#E1E4E8\">) {</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">  .container</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">    max-width</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">1200</span><span style=\"color:#F97583\">px</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>自定义组件</h2>\n<h3>添加自定义 Logo</h3>\n<p>替换默认 Logo：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#6A737D\">&#x3C;!-- 在 index.html 中 --></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">div</span><span style=\"color:#B392F0\"> class</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"logo\"</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  &#x3C;</span><span style=\"color:#85E89D\">img</span><span style=\"color:#B392F0\"> src</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/logo.svg\"</span><span style=\"color:#B392F0\"> alt</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"My Docs\"</span><span style=\"color:#E1E4E8\"> /></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  &#x3C;</span><span style=\"color:#85E89D\">span</span><span style=\"color:#E1E4E8\">>My Documentation&#x3C;/</span><span style=\"color:#85E89D\">span</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;/</span><span style=\"color:#85E89D\">div</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span></code></pre>\n<h3>自定义导航栏</h3>\n<p>添加额外的导航链接：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">template</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  &#x3C;</span><span style=\"color:#85E89D\">header</span><span style=\"color:#B392F0\"> class</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"header\"</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    &#x3C;</span><span style=\"color:#85E89D\">nav</span><span style=\"color:#B392F0\"> class</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"nav\"</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      &#x3C;</span><span style=\"color:#85E89D\">a</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/\"</span><span style=\"color:#E1E4E8\">>首页&#x3C;/</span><span style=\"color:#85E89D\">a</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      &#x3C;</span><span style=\"color:#85E89D\">a</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/docs\"</span><span style=\"color:#E1E4E8\">>文档&#x3C;/</span><span style=\"color:#85E89D\">a</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      &#x3C;</span><span style=\"color:#85E89D\">a</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/blog\"</span><span style=\"color:#E1E4E8\">>博客&#x3C;/</span><span style=\"color:#85E89D\">a</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      &#x3C;</span><span style=\"color:#85E89D\">a</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/about\"</span><span style=\"color:#E1E4E8\">>关于&#x3C;/</span><span style=\"color:#85E89D\">a</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    &#x3C;/</span><span style=\"color:#85E89D\">nav</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  &#x3C;/</span><span style=\"color:#85E89D\">header</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;/</span><span style=\"color:#85E89D\">template</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span></code></pre>\n<h3>添加页脚</h3>\n<p>创建自定义页脚组件：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">template</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  &#x3C;</span><span style=\"color:#85E89D\">footer</span><span style=\"color:#B392F0\"> class</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"footer\"</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    &#x3C;</span><span style=\"color:#85E89D\">div</span><span style=\"color:#B392F0\"> class</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"footer-content\"</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      &#x3C;</span><span style=\"color:#85E89D\">div</span><span style=\"color:#B392F0\"> class</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"footer-section\"</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">        &#x3C;</span><span style=\"color:#85E89D\">h3</span><span style=\"color:#E1E4E8\">>产品&#x3C;/</span><span style=\"color:#85E89D\">h3</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">        &#x3C;</span><span style=\"color:#85E89D\">ul</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">          &#x3C;</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">>&#x3C;</span><span style=\"color:#85E89D\">a</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/features\"</span><span style=\"color:#E1E4E8\">>功能特性&#x3C;/</span><span style=\"color:#85E89D\">a</span><span style=\"color:#E1E4E8\">>&#x3C;/</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">          &#x3C;</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">>&#x3C;</span><span style=\"color:#85E89D\">a</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/pricing\"</span><span style=\"color:#E1E4E8\">>价格方案&#x3C;/</span><span style=\"color:#85E89D\">a</span><span style=\"color:#E1E4E8\">>&#x3C;/</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">          &#x3C;</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">>&#x3C;</span><span style=\"color:#85E89D\">a</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/roadmap\"</span><span style=\"color:#E1E4E8\">>产品路线图&#x3C;/</span><span style=\"color:#85E89D\">a</span><span style=\"color:#E1E4E8\">>&#x3C;/</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">        &#x3C;/</span><span style=\"color:#85E89D\">ul</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      &#x3C;/</span><span style=\"color:#85E89D\">div</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      </span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      &#x3C;</span><span style=\"color:#85E89D\">div</span><span style=\"color:#B392F0\"> class</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"footer-section\"</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">        &#x3C;</span><span style=\"color:#85E89D\">h3</span><span style=\"color:#E1E4E8\">>资源&#x3C;/</span><span style=\"color:#85E89D\">h3</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">        &#x3C;</span><span style=\"color:#85E89D\">ul</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">          &#x3C;</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">>&#x3C;</span><span style=\"color:#85E89D\">a</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/docs\"</span><span style=\"color:#E1E4E8\">>文档&#x3C;/</span><span style=\"color:#85E89D\">a</span><span style=\"color:#E1E4E8\">>&#x3C;/</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">          &#x3C;</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">>&#x3C;</span><span style=\"color:#85E89D\">a</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/api\"</span><span style=\"color:#E1E4E8\">>API 参考&#x3C;/</span><span style=\"color:#85E89D\">a</span><span style=\"color:#E1E4E8\">>&#x3C;/</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">          &#x3C;</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">>&#x3C;</span><span style=\"color:#85E89D\">a</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/examples\"</span><span style=\"color:#E1E4E8\">>示例代码&#x3C;/</span><span style=\"color:#85E89D\">a</span><span style=\"color:#E1E4E8\">>&#x3C;/</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">        &#x3C;/</span><span style=\"color:#85E89D\">ul</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      &#x3C;/</span><span style=\"color:#85E89D\">div</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      </span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      &#x3C;</span><span style=\"color:#85E89D\">div</span><span style=\"color:#B392F0\"> class</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"footer-section\"</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">        &#x3C;</span><span style=\"color:#85E89D\">h3</span><span style=\"color:#E1E4E8\">>社区&#x3C;/</span><span style=\"color:#85E89D\">h3</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">        &#x3C;</span><span style=\"color:#85E89D\">ul</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">          &#x3C;</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">>&#x3C;</span><span style=\"color:#85E89D\">a</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/blog\"</span><span style=\"color:#E1E4E8\">>博客&#x3C;/</span><span style=\"color:#85E89D\">a</span><span style=\"color:#E1E4E8\">>&#x3C;/</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">          &#x3C;</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">>&#x3C;</span><span style=\"color:#85E89D\">a</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/forum\"</span><span style=\"color:#E1E4E8\">>论坛&#x3C;/</span><span style=\"color:#85E89D\">a</span><span style=\"color:#E1E4E8\">>&#x3C;/</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">          &#x3C;</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">>&#x3C;</span><span style=\"color:#85E89D\">a</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/discord\"</span><span style=\"color:#E1E4E8\">>Discord&#x3C;/</span><span style=\"color:#85E89D\">a</span><span style=\"color:#E1E4E8\">>&#x3C;/</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">        &#x3C;/</span><span style=\"color:#85E89D\">ul</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      &#x3C;/</span><span style=\"color:#85E89D\">div</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    &#x3C;/</span><span style=\"color:#85E89D\">div</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    </span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    &#x3C;</span><span style=\"color:#85E89D\">div</span><span style=\"color:#B392F0\"> class</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"footer-bottom\"</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      &#x3C;</span><span style=\"color:#85E89D\">p</span><span style=\"color:#E1E4E8\">></span><span style=\"color:#79B8FF\">&#x26;copy;</span><span style=\"color:#E1E4E8\"> 2026 Your Company. All rights reserved.&#x3C;/</span><span style=\"color:#85E89D\">p</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    &#x3C;/</span><span style=\"color:#85E89D\">div</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  &#x3C;/</span><span style=\"color:#85E89D\">footer</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;/</span><span style=\"color:#85E89D\">template</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">style</span><span style=\"color:#B392F0\"> scoped</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">.footer</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  background</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">var</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">--color-muted</span><span style=\"color:#E1E4E8\">);</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  border-top</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">1</span><span style=\"color:#F97583\">px</span><span style=\"color:#79B8FF\"> solid</span><span style=\"color:#79B8FF\"> var</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">--color-border</span><span style=\"color:#E1E4E8\">);</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  padding</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">3</span><span style=\"color:#F97583\">rem</span><span style=\"color:#79B8FF\"> 0</span><span style=\"color:#79B8FF\"> 1</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  margin-top</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">4</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#B392F0\">.footer-content</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  display</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">grid</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  grid-template-columns</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">repeat</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#79B8FF\">auto-fit</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#79B8FF\">minmax</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#79B8FF\">200</span><span style=\"color:#F97583\">px</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#79B8FF\">1</span><span style=\"color:#F97583\">fr</span><span style=\"color:#E1E4E8\">));</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  gap</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">2</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  max-width</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">1200</span><span style=\"color:#F97583\">px</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  margin</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">0</span><span style=\"color:#79B8FF\"> auto</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  padding</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">0</span><span style=\"color:#79B8FF\"> 2</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#B392F0\">.footer-section</span><span style=\"color:#85E89D\"> h3</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  font-size</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">0.875</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  font-weight</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">600</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  margin-bottom</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">1</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  text-transform</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">uppercase</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  letter-spacing</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">0.05</span><span style=\"color:#F97583\">em</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#B392F0\">.footer-section</span><span style=\"color:#85E89D\"> ul</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  list-style</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">none</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  padding</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">0</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#B392F0\">.footer-section</span><span style=\"color:#85E89D\"> li</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  margin-bottom</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">0.5</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#B392F0\">.footer-section</span><span style=\"color:#85E89D\"> a</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  color</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">var</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">--color-muted-foreground</span><span style=\"color:#E1E4E8\">);</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  text-decoration</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">none</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  font-size</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">0.875</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#B392F0\">.footer-section</span><span style=\"color:#85E89D\"> a</span><span style=\"color:#B392F0\">:hover</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  color</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">var</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">--color-primary</span><span style=\"color:#E1E4E8\">);</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#B392F0\">.footer-bottom</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  text-align</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">center</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  margin-top</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">2</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  padding-top</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">2</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  border-top</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">1</span><span style=\"color:#F97583\">px</span><span style=\"color:#79B8FF\"> solid</span><span style=\"color:#79B8FF\"> var</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">--color-border</span><span style=\"color:#E1E4E8\">);</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  color</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">var</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">--color-muted-foreground</span><span style=\"color:#E1E4E8\">);</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  font-size</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">0.875</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;/</span><span style=\"color:#85E89D\">style</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span></code></pre>\n<h2>自定义 Markdown 渲染</h2>\n<h3>添加自定义容器</h3>\n<p>支持警告、提示等容器：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">::: warning</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">这是一个警告信息</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">:::</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">::: tip</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">这是一个提示信息</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">:::</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">::: danger</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">这是一个危险警告</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">:::</span></span>\n<span class=\"line\"></span></code></pre>\n<p>实现自定义容器：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#E1E4E8\"> MarkdownIt </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> 'markdown-it'</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#E1E4E8\"> container </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> 'markdown-it-container'</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#79B8FF\"> md</span><span style=\"color:#F97583\"> =</span><span style=\"color:#F97583\"> new</span><span style=\"color:#B392F0\"> MarkdownIt</span><span style=\"color:#E1E4E8\">()</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  .</span><span style=\"color:#B392F0\">use</span><span style=\"color:#E1E4E8\">(container, </span><span style=\"color:#9ECBFF\">'warning'</span><span style=\"color:#E1E4E8\">, {</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">    render</span><span style=\"color:#E1E4E8\">: (</span><span style=\"color:#FFAB70\">tokens</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#FFAB70\">idx</span><span style=\"color:#E1E4E8\">) </span><span style=\"color:#F97583\">=></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">      if</span><span style=\"color:#E1E4E8\"> (tokens[idx].nesting </span><span style=\"color:#F97583\">===</span><span style=\"color:#79B8FF\"> 1</span><span style=\"color:#E1E4E8\">) {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">        return</span><span style=\"color:#9ECBFF\"> '&#x3C;div class=\"warning\"></span><span style=\"color:#79B8FF\">\\n</span><span style=\"color:#9ECBFF\">'</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      } </span><span style=\"color:#F97583\">else</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">        return</span><span style=\"color:#9ECBFF\"> '&#x3C;/div></span><span style=\"color:#79B8FF\">\\n</span><span style=\"color:#9ECBFF\">'</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  })</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  .</span><span style=\"color:#B392F0\">use</span><span style=\"color:#E1E4E8\">(container, </span><span style=\"color:#9ECBFF\">'tip'</span><span style=\"color:#E1E4E8\">, {</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">    render</span><span style=\"color:#E1E4E8\">: (</span><span style=\"color:#FFAB70\">tokens</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#FFAB70\">idx</span><span style=\"color:#E1E4E8\">) </span><span style=\"color:#F97583\">=></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">      if</span><span style=\"color:#E1E4E8\"> (tokens[idx].nesting </span><span style=\"color:#F97583\">===</span><span style=\"color:#79B8FF\"> 1</span><span style=\"color:#E1E4E8\">) {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">        return</span><span style=\"color:#9ECBFF\"> '&#x3C;div class=\"tip\"></span><span style=\"color:#79B8FF\">\\n</span><span style=\"color:#9ECBFF\">'</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      } </span><span style=\"color:#F97583\">else</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">        return</span><span style=\"color:#9ECBFF\"> '&#x3C;/div></span><span style=\"color:#79B8FF\">\\n</span><span style=\"color:#9ECBFF\">'</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  })</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>代码块增强</h3>\n<p>添加复制按钮和行号：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">md.renderer.rules.</span><span style=\"color:#B392F0\">fence</span><span style=\"color:#F97583\"> =</span><span style=\"color:#E1E4E8\"> (</span><span style=\"color:#FFAB70\">tokens</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#FFAB70\">idx</span><span style=\"color:#E1E4E8\">) </span><span style=\"color:#F97583\">=></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">  const</span><span style=\"color:#79B8FF\"> token</span><span style=\"color:#F97583\"> =</span><span style=\"color:#E1E4E8\"> tokens[idx]</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">  const</span><span style=\"color:#79B8FF\"> lang</span><span style=\"color:#F97583\"> =</span><span style=\"color:#E1E4E8\"> token.info.</span><span style=\"color:#B392F0\">trim</span><span style=\"color:#E1E4E8\">()</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">  const</span><span style=\"color:#79B8FF\"> code</span><span style=\"color:#F97583\"> =</span><span style=\"color:#E1E4E8\"> token.content</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  </span></span>\n<span class=\"line\"><span style=\"color:#F97583\">  return</span><span style=\"color:#9ECBFF\"> `</span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">    &#x3C;div class=\"code-block\"></span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">      &#x3C;div class=\"code-header\"></span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">        &#x3C;span class=\"language\">${</span><span style=\"color:#E1E4E8\">lang</span><span style=\"color:#9ECBFF\">}&#x3C;/span></span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">        &#x3C;button class=\"copy-button\" onclick=\"copyCode(this)\"></span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">          复制</span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">        &#x3C;/button></span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">      &#x3C;/div></span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">      &#x3C;pre>&#x3C;code class=\"language-${</span><span style=\"color:#E1E4E8\">lang</span><span style=\"color:#9ECBFF\">}\">${</span><span style=\"color:#B392F0\">escapeHtml</span><span style=\"color:#9ECBFF\">(</span><span style=\"color:#E1E4E8\">code</span><span style=\"color:#9ECBFF\">)</span><span style=\"color:#9ECBFF\">}&#x3C;/code>&#x3C;/pre></span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">    &#x3C;/div></span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">  `</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>自动链接标题</h3>\n<p>为所有标题添加锚点链接：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#E1E4E8\"> anchor </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> 'markdown-it-anchor'</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">md.</span><span style=\"color:#B392F0\">use</span><span style=\"color:#E1E4E8\">(anchor, {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  permalink: </span><span style=\"color:#79B8FF\">true</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  permalinkBefore: </span><span style=\"color:#79B8FF\">true</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  permalinkSymbol: </span><span style=\"color:#9ECBFF\">'#'</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  permalinkClass: </span><span style=\"color:#9ECBFF\">'header-anchor'</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">})</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>添加交互功能</h2>\n<h3>代码复制功能</h3>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">function</span><span style=\"color:#B392F0\"> copyCode</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">button</span><span style=\"color:#E1E4E8\">) {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">  const</span><span style=\"color:#79B8FF\"> codeBlock</span><span style=\"color:#F97583\"> =</span><span style=\"color:#E1E4E8\"> button.</span><span style=\"color:#B392F0\">closest</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'.code-block'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">  const</span><span style=\"color:#79B8FF\"> code</span><span style=\"color:#F97583\"> =</span><span style=\"color:#E1E4E8\"> codeBlock.</span><span style=\"color:#B392F0\">querySelector</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'code'</span><span style=\"color:#E1E4E8\">).textContent</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  </span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  navigator.clipboard.</span><span style=\"color:#B392F0\">writeText</span><span style=\"color:#E1E4E8\">(code).</span><span style=\"color:#B392F0\">then</span><span style=\"color:#E1E4E8\">(() </span><span style=\"color:#F97583\">=></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    button.textContent </span><span style=\"color:#F97583\">=</span><span style=\"color:#9ECBFF\"> '已复制!'</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">    setTimeout</span><span style=\"color:#E1E4E8\">(() </span><span style=\"color:#F97583\">=></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      button.textContent </span><span style=\"color:#F97583\">=</span><span style=\"color:#9ECBFF\"> '复制'</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    }, </span><span style=\"color:#79B8FF\">2000</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  })</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>目录高亮</h3>\n<p>滚动时高亮当前章节：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#79B8FF\"> observer</span><span style=\"color:#F97583\"> =</span><span style=\"color:#F97583\"> new</span><span style=\"color:#B392F0\"> IntersectionObserver</span><span style=\"color:#E1E4E8\">((</span><span style=\"color:#FFAB70\">entries</span><span style=\"color:#E1E4E8\">) </span><span style=\"color:#F97583\">=></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  entries.</span><span style=\"color:#B392F0\">forEach</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">entry</span><span style=\"color:#F97583\"> =></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">    if</span><span style=\"color:#E1E4E8\"> (entry.isIntersecting) {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">      const</span><span style=\"color:#79B8FF\"> id</span><span style=\"color:#F97583\"> =</span><span style=\"color:#E1E4E8\"> entry.target.id</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      document.</span><span style=\"color:#B392F0\">querySelectorAll</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'.toc-link'</span><span style=\"color:#E1E4E8\">).</span><span style=\"color:#B392F0\">forEach</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">link</span><span style=\"color:#F97583\"> =></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">        link.classList.</span><span style=\"color:#B392F0\">remove</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'active'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      })</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      document.</span><span style=\"color:#B392F0\">querySelector</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">`a[href=\"#${</span><span style=\"color:#E1E4E8\">id</span><span style=\"color:#9ECBFF\">}\"]`</span><span style=\"color:#E1E4E8\">)?.classList.</span><span style=\"color:#B392F0\">add</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'active'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  })</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}, {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  rootMargin: </span><span style=\"color:#9ECBFF\">'-100px 0px -80% 0px'</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">})</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">document.</span><span style=\"color:#B392F0\">querySelectorAll</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'h2, h3'</span><span style=\"color:#E1E4E8\">).</span><span style=\"color:#B392F0\">forEach</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">heading</span><span style=\"color:#F97583\"> =></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  observer.</span><span style=\"color:#B392F0\">observe</span><span style=\"color:#E1E4E8\">(heading)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">})</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>深色模式切换</h3>\n<p>添加手动切换深色模式：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">template</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  &#x3C;</span><span style=\"color:#85E89D\">button</span><span style=\"color:#B392F0\"> @click</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"toggleDarkMode\"</span><span style=\"color:#B392F0\"> class</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"theme-toggle\"</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    &#x3C;</span><span style=\"color:#85E89D\">span</span><span style=\"color:#B392F0\"> v-if</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"isDark\"</span><span style=\"color:#E1E4E8\">>🌞&#x3C;/</span><span style=\"color:#85E89D\">span</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    &#x3C;</span><span style=\"color:#85E89D\">span</span><span style=\"color:#B392F0\"> v-else</span><span style=\"color:#E1E4E8\">>🌙&#x3C;/</span><span style=\"color:#85E89D\">span</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  &#x3C;/</span><span style=\"color:#85E89D\">button</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;/</span><span style=\"color:#85E89D\">template</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">script</span><span style=\"color:#B392F0\"> setup</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#E1E4E8\"> { ref, onMounted } </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> 'vue'</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#79B8FF\"> isDark</span><span style=\"color:#F97583\"> =</span><span style=\"color:#B392F0\"> ref</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#79B8FF\">false</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#B392F0\">onMounted</span><span style=\"color:#E1E4E8\">(() </span><span style=\"color:#F97583\">=></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  isDark.value </span><span style=\"color:#F97583\">=</span><span style=\"color:#E1E4E8\"> localStorage.</span><span style=\"color:#B392F0\">getItem</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'theme'</span><span style=\"color:#E1E4E8\">) </span><span style=\"color:#F97583\">===</span><span style=\"color:#9ECBFF\"> 'dark'</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">  applyTheme</span><span style=\"color:#E1E4E8\">()</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">})</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#F97583\">function</span><span style=\"color:#B392F0\"> toggleDarkMode</span><span style=\"color:#E1E4E8\">() {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  isDark.value </span><span style=\"color:#F97583\">=</span><span style=\"color:#F97583\"> !</span><span style=\"color:#E1E4E8\">isDark.value</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  localStorage.</span><span style=\"color:#B392F0\">setItem</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'theme'</span><span style=\"color:#E1E4E8\">, isDark.value </span><span style=\"color:#F97583\">?</span><span style=\"color:#9ECBFF\"> 'dark'</span><span style=\"color:#F97583\"> :</span><span style=\"color:#9ECBFF\"> 'light'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">  applyTheme</span><span style=\"color:#E1E4E8\">()</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#F97583\">function</span><span style=\"color:#B392F0\"> applyTheme</span><span style=\"color:#E1E4E8\">() {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">  if</span><span style=\"color:#E1E4E8\"> (isDark.value) {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    document.documentElement.classList.</span><span style=\"color:#B392F0\">add</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'dark'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  } </span><span style=\"color:#F97583\">else</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    document.documentElement.classList.</span><span style=\"color:#B392F0\">remove</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'dark'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;/</span><span style=\"color:#85E89D\">script</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span></code></pre>\n<h2>集成第三方服务</h2>\n<h3>添加评论系统</h3>\n<p>使用 Giscus：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">script</span><span style=\"color:#B392F0\"> src</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"https://giscus.app/client.js\"</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">        data-repo</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"your-username/your-repo\"</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">        data-repo-id</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"your-repo-id\"</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">        data-category</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"Announcements\"</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">        data-category-id</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"your-category-id\"</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">        data-mapping</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"pathname\"</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">        data-reactions-enabled</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"1\"</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">        data-emit-metadata</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"0\"</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">        data-input-position</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"bottom\"</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">        data-theme</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"light\"</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">        data-lang</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"zh-CN\"</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">        crossorigin</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"anonymous\"</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">        async</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;/</span><span style=\"color:#85E89D\">script</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span></code></pre>\n<h3>添加搜索功能</h3>\n<p>集成 Algolia DocSearch：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">link</span><span style=\"color:#B392F0\"> rel</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"stylesheet\"</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"https://cdn.jsdelivr.net/npm/@docsearch/css@3\"</span><span style=\"color:#E1E4E8\"> /></span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">script</span><span style=\"color:#B392F0\"> src</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"https://cdn.jsdelivr.net/npm/@docsearch/js@3\"</span><span style=\"color:#E1E4E8\">>&#x3C;/</span><span style=\"color:#85E89D\">script</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">script</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">  docsearch</span><span style=\"color:#E1E4E8\">({</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    appId: </span><span style=\"color:#9ECBFF\">'YOUR_APP_ID'</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    apiKey: </span><span style=\"color:#9ECBFF\">'YOUR_API_KEY'</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    indexName: </span><span style=\"color:#9ECBFF\">'YOUR_INDEX_NAME'</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    container: </span><span style=\"color:#9ECBFF\">'#docsearch'</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  })</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;/</span><span style=\"color:#85E89D\">script</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span></code></pre>\n<h3>添加分析统计</h3>\n<p>Google Analytics 4：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">script</span><span style=\"color:#B392F0\"> async</span><span style=\"color:#B392F0\"> src</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"https://www.googletagmanager.com/gtag/js?id=G-XXXXXXXXXX\"</span><span style=\"color:#E1E4E8\">>&#x3C;/</span><span style=\"color:#85E89D\">script</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">script</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  window.dataLayer </span><span style=\"color:#F97583\">=</span><span style=\"color:#E1E4E8\"> window.dataLayer </span><span style=\"color:#F97583\">||</span><span style=\"color:#E1E4E8\"> [];</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">  function</span><span style=\"color:#B392F0\"> gtag</span><span style=\"color:#E1E4E8\">(){dataLayer.</span><span style=\"color:#B392F0\">push</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#79B8FF\">arguments</span><span style=\"color:#E1E4E8\">);}</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">  gtag</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'js'</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#F97583\">new</span><span style=\"color:#B392F0\"> Date</span><span style=\"color:#E1E4E8\">());</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">  gtag</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'config'</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#9ECBFF\">'G-XXXXXXXXXX'</span><span style=\"color:#E1E4E8\">);</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;/</span><span style=\"color:#85E89D\">script</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span></code></pre>\n<h2>性能优化</h2>\n<h3>图片懒加载</h3>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">img</span><span style=\"color:#B392F0\"> src</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"placeholder.jpg\"</span><span style=\"color:#E1E4E8\"> </span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">     data-src</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"actual-image.jpg\"</span><span style=\"color:#E1E4E8\"> </span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">     loading</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"lazy\"</span><span style=\"color:#E1E4E8\"> </span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">     alt</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"描述\"</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span></code></pre>\n<h3>预加载关键资源</h3>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">link</span><span style=\"color:#B392F0\"> rel</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"preload\"</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/fonts/inter.woff2\"</span><span style=\"color:#B392F0\"> as</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"font\"</span><span style=\"color:#B392F0\"> type</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"font/woff2\"</span><span style=\"color:#B392F0\"> crossorigin</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">link</span><span style=\"color:#B392F0\"> rel</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"preload\"</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/critical.css\"</span><span style=\"color:#B392F0\"> as</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"style\"</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span></code></pre>\n<h3>Service Worker 缓存</h3>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#6A737D\">// service-worker.js</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">self.</span><span style=\"color:#B392F0\">addEventListener</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'install'</span><span style=\"color:#E1E4E8\">, (</span><span style=\"color:#FFAB70\">event</span><span style=\"color:#E1E4E8\">) </span><span style=\"color:#F97583\">=></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  event.</span><span style=\"color:#B392F0\">waitUntil</span><span style=\"color:#E1E4E8\">(</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    caches.</span><span style=\"color:#B392F0\">open</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'docs-v1'</span><span style=\"color:#E1E4E8\">).</span><span style=\"color:#B392F0\">then</span><span style=\"color:#E1E4E8\">((</span><span style=\"color:#FFAB70\">cache</span><span style=\"color:#E1E4E8\">) </span><span style=\"color:#F97583\">=></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">      return</span><span style=\"color:#E1E4E8\"> cache.</span><span style=\"color:#B392F0\">addAll</span><span style=\"color:#E1E4E8\">([</span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">        '/'</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">        '/index.html'</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">        '/assets/main.css'</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">        '/assets/main.js'</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      ])</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    })</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  )</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">})</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">self.</span><span style=\"color:#B392F0\">addEventListener</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'fetch'</span><span style=\"color:#E1E4E8\">, (</span><span style=\"color:#FFAB70\">event</span><span style=\"color:#E1E4E8\">) </span><span style=\"color:#F97583\">=></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  event.</span><span style=\"color:#B392F0\">respondWith</span><span style=\"color:#E1E4E8\">(</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    caches.</span><span style=\"color:#B392F0\">match</span><span style=\"color:#E1E4E8\">(event.request).</span><span style=\"color:#B392F0\">then</span><span style=\"color:#E1E4E8\">((</span><span style=\"color:#FFAB70\">response</span><span style=\"color:#E1E4E8\">) </span><span style=\"color:#F97583\">=></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">      return</span><span style=\"color:#E1E4E8\"> response </span><span style=\"color:#F97583\">||</span><span style=\"color:#B392F0\"> fetch</span><span style=\"color:#E1E4E8\">(event.request)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    })</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  )</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">})</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>总结</h2>\n<p>通过这些自定义选项，你可以：</p>\n<ul>\n<li>✅ 创建独特的视觉风格</li>\n<li>✅ 添加自定义功能组件</li>\n<li>✅ 增强 Markdown 渲染</li>\n<li>✅ 集成第三方服务</li>\n<li>✅ 优化性能和用户体验</li>\n</ul>\n<p>继续探索更多可能性！</p>\n","headings":[]},"lastModified":1768789337931}],"directories":[{"path":"/Users/pan/docgen/my-docs/api","name":"api","children":[{"path":"/Users/pan/docgen/my-docs/api/README.md","name":"README.md","title":"API 参考","description":"DocGen API 完整参考文档","content":"\n# API 参考\n\nDocGen 提供了简洁而强大的 API，用于生成和管理文档站点。\n\n## 核心 API\n\n### scanSkillsDirectory()\n\n扫描指定目录，收集所有 Markdown 文件。\n\n```typescript\nasync function scanSkillsDirectory(dirPath: string): Promise<SkillDirectory[]>\n```\n\n**参数：**\n- `dirPath` (string): 要扫描的目录路径\n\n**返回值：**\n- `Promise<SkillDirectory[]>`: 目录结构数组\n\n**示例：**\n\n```typescript\nimport { scanSkillsDirectory } from 'docgen'\n\nconst directories = await scanSkillsDirectory('./docs')\nconsole.log(`找到 ${directories.length} 个目录`)\n```\n\n### parseSkillsToConfig()\n\n将扫描的目录结构解析为配置对象。\n\n```typescript\nasync function parseSkillsToConfig(\n  directories: SkillDirectory[],\n  siteConfig: SiteConfig\n): Promise<DocGenConfig>\n```\n\n**参数：**\n- `directories` (SkillDirectory[]): 目录结构数组\n- `siteConfig` (SiteConfig): 站点配置对象\n\n**返回值：**\n- `Promise<DocGenConfig>`: 完整的文档配置\n\n**示例：**\n\n```typescript\nconst config = await parseSkillsToConfig(directories, {\n  title: '我的文档',\n  description: '项目文档站点',\n  baseUrl: '/',\n  skillsDir: './docs',\n  outputDir: './dist'\n})\n```\n\n## 类型定义\n\n### SkillFile\n\n表示单个 Markdown 文件。\n\n```typescript\ninterface SkillFile {\n  path: string           // 文件绝对路径\n  name: string           // 文件名\n  title?: string         // 文档标题\n  description?: string   // 文档描述\n  content: string        // Markdown 内容\n  frontmatter: Record<string, any>  // 前置元数据\n  lastModified: number   // 最后修改时间戳\n}\n```\n\n### SiteConfig\n\n站点配置对象。\n\n```typescript\ninterface SiteConfig {\n  title: string          // 站点标题\n  description: string    // 站点描述\n  baseUrl: string        // 基础 URL\n  skillsDir: string      // 源文件目录\n  outputDir: string      // 输出目录\n}\n```\n\n## CLI 命令\n\n### dev\n\n启动开发服务器。\n\n```bash\ndocgen dev [options]\n```\n\n**选项：**\n- `--dir <path>`: 源文件目录（默认：`./docs`）\n- `--port <number>`: 端口号（默认：`3000`）\n\n### build\n\n构建静态站点。\n\n```bash\ndocgen build [options]\n```\n\n**选项：**\n- `--dir <path>`: 源文件目录（默认：`./docs`）\n- `--output <path>`: 输出目录（默认：`./dist`）\n\n### preview\n\n预览构建后的站点。\n\n```bash\ndocgen preview [options]\n```\n\n**选项：**\n- `--output <path>`: 站点目录（默认：`./dist`）\n- `--port <number>`: 端口号（默认：`4173`）\n\n## 错误处理\n\n所有异步函数都会抛出错误，建议使用 try-catch 处理：\n\n```typescript\ntry {\n  const directories = await scanSkillsDirectory('./docs')\n} catch (error) {\n  console.error('扫描失败:', error)\n}\n```\n\n## 最佳实践\n\n1. **使用 TypeScript**：获得完整的类型提示\n2. **错误处理**：始终捕获异步操作的错误\n3. **路径规范**：使用绝对路径避免路径问题\n4. **配置验证**：构建前验证配置对象的完整性\n","frontmatter":{"title":"API 参考","description":"DocGen API 完整参考文档","html":"<h1>API 参考</h1>\n<p>DocGen 提供了简洁而强大的 API，用于生成和管理文档站点。</p>\n<h2>核心 API</h2>\n<h3>scanSkillsDirectory()</h3>\n<p>扫描指定目录，收集所有 Markdown 文件。</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">async</span><span style=\"color:#F97583\"> function</span><span style=\"color:#B392F0\"> scanSkillsDirectory</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">dirPath</span><span style=\"color:#F97583\">:</span><span style=\"color:#79B8FF\"> string</span><span style=\"color:#E1E4E8\">)</span><span style=\"color:#F97583\">:</span><span style=\"color:#B392F0\"> Promise</span><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#B392F0\">SkillDirectory</span><span style=\"color:#E1E4E8\">[]></span></span>\n<span class=\"line\"></span></code></pre>\n<p><strong>参数：</strong></p>\n<ul>\n<li><code>dirPath</code> (string): 要扫描的目录路径</li>\n</ul>\n<p><strong>返回值：</strong></p>\n<ul>\n<li><code>Promise&lt;SkillDirectory[]&gt;</code>: 目录结构数组</li>\n</ul>\n<p><strong>示例：</strong></p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#E1E4E8\"> { scanSkillsDirectory } </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> 'docgen'</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#79B8FF\"> directories</span><span style=\"color:#F97583\"> =</span><span style=\"color:#F97583\"> await</span><span style=\"color:#B392F0\"> scanSkillsDirectory</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'./docs'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">console.</span><span style=\"color:#B392F0\">log</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">`找到 ${</span><span style=\"color:#E1E4E8\">directories</span><span style=\"color:#9ECBFF\">.</span><span style=\"color:#79B8FF\">length</span><span style=\"color:#9ECBFF\">} 个目录`</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>parseSkillsToConfig()</h3>\n<p>将扫描的目录结构解析为配置对象。</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">async</span><span style=\"color:#F97583\"> function</span><span style=\"color:#B392F0\"> parseSkillsToConfig</span><span style=\"color:#E1E4E8\">(</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  directories</span><span style=\"color:#F97583\">:</span><span style=\"color:#B392F0\"> SkillDirectory</span><span style=\"color:#E1E4E8\">[],</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  siteConfig</span><span style=\"color:#F97583\">:</span><span style=\"color:#B392F0\"> SiteConfig</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">)</span><span style=\"color:#F97583\">:</span><span style=\"color:#B392F0\"> Promise</span><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#B392F0\">DocGenConfig</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span></code></pre>\n<p><strong>参数：</strong></p>\n<ul>\n<li><code>directories</code> (SkillDirectory[]): 目录结构数组</li>\n<li><code>siteConfig</code> (SiteConfig): 站点配置对象</li>\n</ul>\n<p><strong>返回值：</strong></p>\n<ul>\n<li><code>Promise&lt;DocGenConfig&gt;</code>: 完整的文档配置</li>\n</ul>\n<p><strong>示例：</strong></p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#79B8FF\"> config</span><span style=\"color:#F97583\"> =</span><span style=\"color:#F97583\"> await</span><span style=\"color:#B392F0\"> parseSkillsToConfig</span><span style=\"color:#E1E4E8\">(directories, {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  title: </span><span style=\"color:#9ECBFF\">'我的文档'</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  description: </span><span style=\"color:#9ECBFF\">'项目文档站点'</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  baseUrl: </span><span style=\"color:#9ECBFF\">'/'</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  skillsDir: </span><span style=\"color:#9ECBFF\">'./docs'</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  outputDir: </span><span style=\"color:#9ECBFF\">'./dist'</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">})</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>类型定义</h2>\n<h3>SkillFile</h3>\n<p>表示单个 Markdown 文件。</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">interface</span><span style=\"color:#B392F0\"> SkillFile</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  path</span><span style=\"color:#F97583\">:</span><span style=\"color:#79B8FF\"> string</span><span style=\"color:#6A737D\">           // 文件绝对路径</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  name</span><span style=\"color:#F97583\">:</span><span style=\"color:#79B8FF\"> string</span><span style=\"color:#6A737D\">           // 文件名</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  title</span><span style=\"color:#F97583\">?:</span><span style=\"color:#79B8FF\"> string</span><span style=\"color:#6A737D\">         // 文档标题</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  description</span><span style=\"color:#F97583\">?:</span><span style=\"color:#79B8FF\"> string</span><span style=\"color:#6A737D\">   // 文档描述</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  content</span><span style=\"color:#F97583\">:</span><span style=\"color:#79B8FF\"> string</span><span style=\"color:#6A737D\">        // Markdown 内容</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  frontmatter</span><span style=\"color:#F97583\">:</span><span style=\"color:#B392F0\"> Record</span><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#79B8FF\">string</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#79B8FF\">any</span><span style=\"color:#E1E4E8\">>  </span><span style=\"color:#6A737D\">// 前置元数据</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  lastModified</span><span style=\"color:#F97583\">:</span><span style=\"color:#79B8FF\"> number</span><span style=\"color:#6A737D\">   // 最后修改时间戳</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>SiteConfig</h3>\n<p>站点配置对象。</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">interface</span><span style=\"color:#B392F0\"> SiteConfig</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  title</span><span style=\"color:#F97583\">:</span><span style=\"color:#79B8FF\"> string</span><span style=\"color:#6A737D\">          // 站点标题</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  description</span><span style=\"color:#F97583\">:</span><span style=\"color:#79B8FF\"> string</span><span style=\"color:#6A737D\">    // 站点描述</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  baseUrl</span><span style=\"color:#F97583\">:</span><span style=\"color:#79B8FF\"> string</span><span style=\"color:#6A737D\">        // 基础 URL</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  skillsDir</span><span style=\"color:#F97583\">:</span><span style=\"color:#79B8FF\"> string</span><span style=\"color:#6A737D\">      // 源文件目录</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  outputDir</span><span style=\"color:#F97583\">:</span><span style=\"color:#79B8FF\"> string</span><span style=\"color:#6A737D\">      // 输出目录</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>CLI 命令</h2>\n<h3>dev</h3>\n<p>启动开发服务器。</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">docgen</span><span style=\"color:#9ECBFF\"> dev</span><span style=\"color:#E1E4E8\"> [options]</span></span>\n<span class=\"line\"></span></code></pre>\n<p><strong>选项：</strong></p>\n<ul>\n<li><code>--dir &lt;path&gt;</code>: 源文件目录（默认：<code>./docs</code>）</li>\n<li><code>--port &lt;number&gt;</code>: 端口号（默认：<code>3000</code>）</li>\n</ul>\n<h3>build</h3>\n<p>构建静态站点。</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">docgen</span><span style=\"color:#9ECBFF\"> build</span><span style=\"color:#E1E4E8\"> [options]</span></span>\n<span class=\"line\"></span></code></pre>\n<p><strong>选项：</strong></p>\n<ul>\n<li><code>--dir &lt;path&gt;</code>: 源文件目录（默认：<code>./docs</code>）</li>\n<li><code>--output &lt;path&gt;</code>: 输出目录（默认：<code>./dist</code>）</li>\n</ul>\n<h3>preview</h3>\n<p>预览构建后的站点。</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">docgen</span><span style=\"color:#9ECBFF\"> preview</span><span style=\"color:#E1E4E8\"> [options]</span></span>\n<span class=\"line\"></span></code></pre>\n<p><strong>选项：</strong></p>\n<ul>\n<li><code>--output &lt;path&gt;</code>: 站点目录（默认：<code>./dist</code>）</li>\n<li><code>--port &lt;number&gt;</code>: 端口号（默认：<code>4173</code>）</li>\n</ul>\n<h2>错误处理</h2>\n<p>所有异步函数都会抛出错误，建议使用 try-catch 处理：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">try</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">  const</span><span style=\"color:#79B8FF\"> directories</span><span style=\"color:#F97583\"> =</span><span style=\"color:#F97583\"> await</span><span style=\"color:#B392F0\"> scanSkillsDirectory</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'./docs'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">} </span><span style=\"color:#F97583\">catch</span><span style=\"color:#E1E4E8\"> (error) {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  console.</span><span style=\"color:#B392F0\">error</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'扫描失败:'</span><span style=\"color:#E1E4E8\">, error)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>最佳实践</h2>\n<ol>\n<li><strong>使用 TypeScript</strong>：获得完整的类型提示</li>\n<li><strong>错误处理</strong>：始终捕获异步操作的错误</li>\n<li><strong>路径规范</strong>：使用绝对路径避免路径问题</li>\n<li><strong>配置验证</strong>：构建前验证配置对象的完整性</li>\n</ol>\n","headings":[]},"lastModified":1768789238184},{"path":"/Users/pan/docgen/my-docs/api/advanced.md","name":"advanced.md","title":"高级用法","description":"DocGen 高级功能和自定义选项","content":"\n# 高级用法\n\n深入了解 DocGen 的高级功能和自定义选项。\n\n## 自定义主题\n\n### CSS 变量\n\nDocGen 使用 CSS 变量系统，可以轻松自定义主题：\n\n```css\n:root {\n  --color-primary: #0a0a0a;\n  --color-background: #ffffff;\n  --font-sans: -apple-system, sans-serif;\n  --spacing-md: 1rem;\n  --radius-lg: 0.75rem;\n}\n```\n\n### 深色模式\n\n系统自动支持深色模式，基于用户系统偏好：\n\n```css\n@media (prefers-color-scheme: dark) {\n  :root {\n    --color-background: #0a0a0a;\n    --color-foreground: #fafafa;\n  }\n}\n```\n\n## 插件系统\n\n### Vite 插件集成\n\nDocGen 基于 Vite 构建，可以使用任何 Vite 插件：\n\n```typescript\nimport { defineConfig } from 'vite'\nimport vue from '@vitejs/plugin-vue'\nimport markdown from 'vite-plugin-markdown'\n\nexport default defineConfig({\n  plugins: [\n    vue(),\n    markdown()\n  ]\n})\n```\n\n### Markdown-it 扩展\n\n自定义 Markdown 渲染器：\n\n```typescript\nimport MarkdownIt from 'markdown-it'\nimport anchor from 'markdown-it-anchor'\nimport toc from 'markdown-it-toc-done-right'\n\nconst md = new MarkdownIt({\n  html: true,\n  linkify: true,\n  typographer: true\n})\n  .use(anchor)\n  .use(toc)\n```\n\n## 性能优化\n\n### 代码分割\n\n使用动态导入优化加载性能：\n\n```typescript\nconst Home = () => import('./pages/Home.vue')\nconst SkillPage = () => import('./pages/SkillPage.vue')\n```\n\n### 图片优化\n\n建议使用 WebP 格式和响应式图片：\n\n```markdown\n![示例图片](./image.webp)\n```\n\n### 懒加载\n\n对大型文档启用懒加载：\n\n```typescript\nconst observer = new IntersectionObserver((entries) => {\n  entries.forEach(entry => {\n    if (entry.isIntersecting) {\n      // 加载内容\n    }\n  })\n})\n```\n\n## 部署选项\n\n### Netlify\n\n```toml\n[build]\n  command = \"docgen build --dir ./docs --output ./dist\"\n  publish = \"dist\"\n\n[[redirects]]\n  from = \"/*\"\n  to = \"/index.html\"\n  status = 200\n```\n\n### Vercel\n\n```json\n{\n  \"buildCommand\": \"docgen build --dir ./docs --output ./dist\",\n  \"outputDirectory\": \"dist\",\n  \"rewrites\": [\n    { \"source\": \"/(.*)\", \"destination\": \"/index.html\" }\n  ]\n}\n```\n\n### GitHub Pages\n\n```yaml\nname: Deploy\non:\n  push:\n    branches: [main]\njobs:\n  deploy:\n    runs-on: ubuntu-latest\n    steps:\n      - uses: actions/checkout@v2\n      - run: npm install\n      - run: docgen build --dir ./docs --output ./dist\n      - uses: peaceiris/actions-gh-pages@v3\n        with:\n          github_token: ${{ secrets.GITHUB_TOKEN }}\n          publish_dir: ./dist\n```\n\n## 搜索优化\n\n### 全文搜索\n\n实现基于 Fuse.js 的全文搜索：\n\n```typescript\nimport Fuse from 'fuse.js'\n\nconst fuse = new Fuse(files, {\n  keys: ['title', 'content', 'description'],\n  threshold: 0.3\n})\n\nconst results = fuse.search(query)\n```\n\n### SEO 优化\n\n生成 sitemap 和 robots.txt：\n\n```typescript\n// sitemap.xml\nconst urls = files.map(file => ({\n  loc: `${baseUrl}${getFileRoute(file)}`,\n  lastmod: new Date(file.lastModified).toISOString()\n}))\n```\n\n## 国际化\n\n### 多语言支持\n\n组织多语言文档：\n\n```\ndocs/\n  en/\n    getting-started/\n      README.md\n  zh/\n    getting-started/\n      README.md\n```\n\n### 语言切换\n\n```typescript\nconst locale = ref('zh')\n\nfunction switchLocale(newLocale: string) {\n  locale.value = newLocale\n  // 重新加载文档\n}\n```\n\n## 安全性\n\n### 内容安全策略\n\n配置 CSP 头：\n\n```html\n<meta http-equiv=\"Content-Security-Policy\" \n      content=\"default-src 'self'; script-src 'self' 'unsafe-inline'\">\n```\n\n### XSS 防护\n\nMarkdown 渲染时自动转义 HTML：\n\n```typescript\nconst md = new MarkdownIt({\n  html: false  // 禁用原始 HTML\n})\n```\n\n## 监控和分析\n\n### Google Analytics\n\n```html\n<script async src=\"https://www.googletagmanager.com/gtag/js?id=GA_ID\"></script>\n<script>\n  window.dataLayer = window.dataLayer || [];\n  function gtag(){dataLayer.push(arguments);}\n  gtag('js', new Date());\n  gtag('config', 'GA_ID');\n</script>\n```\n\n### 错误追踪\n\n集成 Sentry：\n\n```typescript\nimport * as Sentry from '@sentry/vue'\n\nSentry.init({\n  app,\n  dsn: 'YOUR_DSN',\n  integrations: [new Sentry.BrowserTracing()],\n  tracesSampleRate: 1.0\n})\n```\n","frontmatter":{"title":"高级用法","description":"DocGen 高级功能和自定义选项","html":"<h1>高级用法</h1>\n<p>深入了解 DocGen 的高级功能和自定义选项。</p>\n<h2>自定义主题</h2>\n<h3>CSS 变量</h3>\n<p>DocGen 使用 CSS 变量系统，可以轻松自定义主题：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">:root</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --color-primary</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">#0a0a0a</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --color-background</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">#ffffff</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --font-sans</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">-apple-system</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#79B8FF\">sans-serif</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --spacing-md</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">1</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --radius-lg</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">0.75</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>深色模式</h3>\n<p>系统自动支持深色模式，基于用户系统偏好：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">@media</span><span style=\"color:#E1E4E8\"> (prefers-color-scheme: dark) {</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">  :root</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">    --color-background</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">#0a0a0a</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">    --color-foreground</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">#fafafa</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>插件系统</h2>\n<h3>Vite 插件集成</h3>\n<p>DocGen 基于 Vite 构建，可以使用任何 Vite 插件：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#E1E4E8\"> { defineConfig } </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> 'vite'</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#E1E4E8\"> vue </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> '@vitejs/plugin-vue'</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#E1E4E8\"> markdown </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> 'vite-plugin-markdown'</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#F97583\">export</span><span style=\"color:#F97583\"> default</span><span style=\"color:#B392F0\"> defineConfig</span><span style=\"color:#E1E4E8\">({</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  plugins: [</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">    vue</span><span style=\"color:#E1E4E8\">(),</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">    markdown</span><span style=\"color:#E1E4E8\">()</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  ]</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">})</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>Markdown-it 扩展</h3>\n<p>自定义 Markdown 渲染器：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#E1E4E8\"> MarkdownIt </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> 'markdown-it'</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#E1E4E8\"> anchor </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> 'markdown-it-anchor'</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#E1E4E8\"> toc </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> 'markdown-it-toc-done-right'</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#79B8FF\"> md</span><span style=\"color:#F97583\"> =</span><span style=\"color:#F97583\"> new</span><span style=\"color:#B392F0\"> MarkdownIt</span><span style=\"color:#E1E4E8\">({</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  html: </span><span style=\"color:#79B8FF\">true</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  linkify: </span><span style=\"color:#79B8FF\">true</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  typographer: </span><span style=\"color:#79B8FF\">true</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">})</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  .</span><span style=\"color:#B392F0\">use</span><span style=\"color:#E1E4E8\">(anchor)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  .</span><span style=\"color:#B392F0\">use</span><span style=\"color:#E1E4E8\">(toc)</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>性能优化</h2>\n<h3>代码分割</h3>\n<p>使用动态导入优化加载性能：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#B392F0\"> Home</span><span style=\"color:#F97583\"> =</span><span style=\"color:#E1E4E8\"> () </span><span style=\"color:#F97583\">=></span><span style=\"color:#F97583\"> import</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'./pages/Home.vue'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#B392F0\"> SkillPage</span><span style=\"color:#F97583\"> =</span><span style=\"color:#E1E4E8\"> () </span><span style=\"color:#F97583\">=></span><span style=\"color:#F97583\"> import</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'./pages/SkillPage.vue'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>图片优化</h3>\n<p>建议使用 WebP 格式和响应式图片：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">![</span><span style=\"color:#DBEDFF;text-decoration:underline\">示例图片</span><span style=\"color:#E1E4E8\">](</span><span style=\"color:#E1E4E8;text-decoration:underline\">./image.webp</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>懒加载</h3>\n<p>对大型文档启用懒加载：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#79B8FF\"> observer</span><span style=\"color:#F97583\"> =</span><span style=\"color:#F97583\"> new</span><span style=\"color:#B392F0\"> IntersectionObserver</span><span style=\"color:#E1E4E8\">((</span><span style=\"color:#FFAB70\">entries</span><span style=\"color:#E1E4E8\">) </span><span style=\"color:#F97583\">=></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  entries.</span><span style=\"color:#B392F0\">forEach</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">entry</span><span style=\"color:#F97583\"> =></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">    if</span><span style=\"color:#E1E4E8\"> (entry.isIntersecting) {</span></span>\n<span class=\"line\"><span style=\"color:#6A737D\">      // 加载内容</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  })</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">})</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>部署选项</h2>\n<h3>Netlify</h3>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span>[build]</span></span>\n<span class=\"line\"><span>  command = \"docgen build --dir ./docs --output ./dist\"</span></span>\n<span class=\"line\"><span>  publish = \"dist\"</span></span>\n<span class=\"line\"><span></span></span>\n<span class=\"line\"><span>[[redirects]]</span></span>\n<span class=\"line\"><span>  from = \"/*\"</span></span>\n<span class=\"line\"><span>  to = \"/index.html\"</span></span>\n<span class=\"line\"><span>  status = 200</span></span>\n<span class=\"line\"><span></span></span></code></pre>\n<h3>Vercel</h3>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">{</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  \"buildCommand\"</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">\"docgen build --dir ./docs --output ./dist\"</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  \"outputDirectory\"</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">\"dist\"</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  \"rewrites\"</span><span style=\"color:#E1E4E8\">: [</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    { </span><span style=\"color:#79B8FF\">\"source\"</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">\"/(.*)\"</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#79B8FF\">\"destination\"</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">\"/index.html\"</span><span style=\"color:#E1E4E8\"> }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  ]</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>GitHub Pages</h3>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#85E89D\">name</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">Deploy</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">on</span><span style=\"color:#E1E4E8\">:</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">  push</span><span style=\"color:#E1E4E8\">:</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">    branches</span><span style=\"color:#E1E4E8\">: [</span><span style=\"color:#9ECBFF\">main</span><span style=\"color:#E1E4E8\">]</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">jobs</span><span style=\"color:#E1E4E8\">:</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">  deploy</span><span style=\"color:#E1E4E8\">:</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">    runs-on</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">ubuntu-latest</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">    steps</span><span style=\"color:#E1E4E8\">:</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      - </span><span style=\"color:#85E89D\">uses</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">actions/checkout@v2</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      - </span><span style=\"color:#85E89D\">run</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">npm install</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      - </span><span style=\"color:#85E89D\">run</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">docgen build --dir ./docs --output ./dist</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      - </span><span style=\"color:#85E89D\">uses</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">peaceiris/actions-gh-pages@v3</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">        with</span><span style=\"color:#E1E4E8\">:</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">          github_token</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">${{ secrets.GITHUB_TOKEN }}</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">          publish_dir</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">./dist</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>搜索优化</h2>\n<h3>全文搜索</h3>\n<p>实现基于 Fuse.js 的全文搜索：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#E1E4E8\"> Fuse </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> 'fuse.js'</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#79B8FF\"> fuse</span><span style=\"color:#F97583\"> =</span><span style=\"color:#F97583\"> new</span><span style=\"color:#B392F0\"> Fuse</span><span style=\"color:#E1E4E8\">(files, {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  keys: [</span><span style=\"color:#9ECBFF\">'title'</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#9ECBFF\">'content'</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#9ECBFF\">'description'</span><span style=\"color:#E1E4E8\">],</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  threshold: </span><span style=\"color:#79B8FF\">0.3</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">})</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#79B8FF\"> results</span><span style=\"color:#F97583\"> =</span><span style=\"color:#E1E4E8\"> fuse.</span><span style=\"color:#B392F0\">search</span><span style=\"color:#E1E4E8\">(query)</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>SEO 优化</h3>\n<p>生成 sitemap 和 robots.txt：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#6A737D\">// sitemap.xml</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#79B8FF\"> urls</span><span style=\"color:#F97583\"> =</span><span style=\"color:#E1E4E8\"> files.</span><span style=\"color:#B392F0\">map</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">file</span><span style=\"color:#F97583\"> =></span><span style=\"color:#E1E4E8\"> ({</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  loc: </span><span style=\"color:#9ECBFF\">`${</span><span style=\"color:#E1E4E8\">baseUrl</span><span style=\"color:#9ECBFF\">}${</span><span style=\"color:#B392F0\">getFileRoute</span><span style=\"color:#9ECBFF\">(</span><span style=\"color:#E1E4E8\">file</span><span style=\"color:#9ECBFF\">)</span><span style=\"color:#9ECBFF\">}`</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  lastmod: </span><span style=\"color:#F97583\">new</span><span style=\"color:#B392F0\"> Date</span><span style=\"color:#E1E4E8\">(file.lastModified).</span><span style=\"color:#B392F0\">toISOString</span><span style=\"color:#E1E4E8\">()</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}))</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>国际化</h2>\n<h3>多语言支持</h3>\n<p>组织多语言文档：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span>docs/</span></span>\n<span class=\"line\"><span>  en/</span></span>\n<span class=\"line\"><span>    getting-started/</span></span>\n<span class=\"line\"><span>      README.md</span></span>\n<span class=\"line\"><span>  zh/</span></span>\n<span class=\"line\"><span>    getting-started/</span></span>\n<span class=\"line\"><span>      README.md</span></span>\n<span class=\"line\"><span></span></span></code></pre>\n<h3>语言切换</h3>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#79B8FF\"> locale</span><span style=\"color:#F97583\"> =</span><span style=\"color:#B392F0\"> ref</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'zh'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#F97583\">function</span><span style=\"color:#B392F0\"> switchLocale</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">newLocale</span><span style=\"color:#F97583\">:</span><span style=\"color:#79B8FF\"> string</span><span style=\"color:#E1E4E8\">) {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  locale.value </span><span style=\"color:#F97583\">=</span><span style=\"color:#E1E4E8\"> newLocale</span></span>\n<span class=\"line\"><span style=\"color:#6A737D\">  // 重新加载文档</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>安全性</h2>\n<h3>内容安全策略</h3>\n<p>配置 CSP 头：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">meta</span><span style=\"color:#B392F0\"> http-equiv</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"Content-Security-Policy\"</span><span style=\"color:#E1E4E8\"> </span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">      content</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"default-src 'self'; script-src 'self' 'unsafe-inline'\"</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span></code></pre>\n<h3>XSS 防护</h3>\n<p>Markdown 渲染时自动转义 HTML：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#79B8FF\"> md</span><span style=\"color:#F97583\"> =</span><span style=\"color:#F97583\"> new</span><span style=\"color:#B392F0\"> MarkdownIt</span><span style=\"color:#E1E4E8\">({</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  html: </span><span style=\"color:#79B8FF\">false</span><span style=\"color:#6A737D\">  // 禁用原始 HTML</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">})</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>监控和分析</h2>\n<h3>Google Analytics</h3>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">script</span><span style=\"color:#B392F0\"> async</span><span style=\"color:#B392F0\"> src</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"https://www.googletagmanager.com/gtag/js?id=GA_ID\"</span><span style=\"color:#E1E4E8\">>&#x3C;/</span><span style=\"color:#85E89D\">script</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">script</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  window.dataLayer </span><span style=\"color:#F97583\">=</span><span style=\"color:#E1E4E8\"> window.dataLayer </span><span style=\"color:#F97583\">||</span><span style=\"color:#E1E4E8\"> [];</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">  function</span><span style=\"color:#B392F0\"> gtag</span><span style=\"color:#E1E4E8\">(){dataLayer.</span><span style=\"color:#B392F0\">push</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#79B8FF\">arguments</span><span style=\"color:#E1E4E8\">);}</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">  gtag</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'js'</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#F97583\">new</span><span style=\"color:#B392F0\"> Date</span><span style=\"color:#E1E4E8\">());</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">  gtag</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'config'</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#9ECBFF\">'GA_ID'</span><span style=\"color:#E1E4E8\">);</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;/</span><span style=\"color:#85E89D\">script</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span></code></pre>\n<h3>错误追踪</h3>\n<p>集成 Sentry：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#79B8FF\"> *</span><span style=\"color:#F97583\"> as</span><span style=\"color:#E1E4E8\"> Sentry </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> '@sentry/vue'</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">Sentry.</span><span style=\"color:#B392F0\">init</span><span style=\"color:#E1E4E8\">({</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  app,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  dsn: </span><span style=\"color:#9ECBFF\">'YOUR_DSN'</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  integrations: [</span><span style=\"color:#F97583\">new</span><span style=\"color:#E1E4E8\"> Sentry.</span><span style=\"color:#B392F0\">BrowserTracing</span><span style=\"color:#E1E4E8\">()],</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  tracesSampleRate: </span><span style=\"color:#79B8FF\">1.0</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">})</span></span>\n<span class=\"line\"></span></code></pre>\n","headings":[]},"lastModified":1768789263861}]},{"path":"/Users/pan/docgen/my-docs/configuration","name":"configuration","children":[]},{"path":"/Users/pan/docgen/my-docs/faq","name":"faq","children":[]},{"path":"/Users/pan/docgen/my-docs/getting-started","name":"getting-started","children":[{"path":"/Users/pan/docgen/my-docs/getting-started/README.md","name":"README.md","title":"快速开始","description":"DocGen 快速入门指南","content":"\n# 快速开始\n\n欢迎使用 DocGen！这是一个用于生成文档网站的工具。\n\n## 安装\n\n```bash\nnpm install -g docgen\n```\n\n## 基本使用\n\n创建你的文档目录结构，然后运行：\n\n```bash\ndocgen dev --dir ./my-docs\n```\n\n就这么简单！\n","frontmatter":{"title":"快速开始","description":"DocGen 快速入门指南","html":"<h1>快速开始</h1>\n<p>欢迎使用 DocGen！这是一个用于生成文档网站的工具。</p>\n<h2>安装</h2>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">npm</span><span style=\"color:#9ECBFF\"> install</span><span style=\"color:#79B8FF\"> -g</span><span style=\"color:#9ECBFF\"> docgen</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>基本使用</h2>\n<p>创建你的文档目录结构，然后运行：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">docgen</span><span style=\"color:#9ECBFF\"> dev</span><span style=\"color:#79B8FF\"> --dir</span><span style=\"color:#9ECBFF\"> ./my-docs</span></span>\n<span class=\"line\"></span></code></pre>\n<p>就这么简单！</p>\n","headings":[]},"lastModified":1768787451416}]},{"path":"/Users/pan/docgen/my-docs/tutorials","name":"tutorials","children":[{"path":"/Users/pan/docgen/my-docs/tutorials/README.md","name":"README.md","title":"教程指南","description":"从零开始学习使用 DocGen","content":"\n# 教程指南\n\n通过实际示例学习如何使用 DocGen 构建文档站点。\n\n## 第一步：创建项目\n\n### 1. 安装 DocGen\n\n首先安装 DocGen CLI 工具：\n\n```bash\nnpm install -g docgen\n```\n\n验证安装：\n\n```bash\ndocgen --version\n```\n\n### 2. 创建文档目录\n\n创建你的文档项目结构：\n\n```bash\nmkdir my-documentation\ncd my-documentation\nmkdir docs\n```\n\n### 3. 编写第一个文档\n\n创建 `docs/getting-started/README.md`：\n\n```markdown\n---\ntitle: 快速开始\ndescription: 开始使用我们的产品\n---\n\n# 快速开始\n\n欢迎使用我们的产品！\n\n## 安装\n\n\\`\\`\\`bash\nnpm install my-product\n\\`\\`\\`\n\n## 基本用法\n\n\\`\\`\\`javascript\nimport { MyProduct } from 'my-product'\n\nconst product = new MyProduct()\nproduct.start()\n\\`\\`\\`\n```\n\n## 第二步：启动开发服务器\n\n### 实时预览\n\n启动开发服务器查看效果：\n\n```bash\ndocgen dev --dir ./docs\n```\n\n访问 `http://localhost:3000` 查看你的文档站点。\n\n### 热更新\n\n修改任何 Markdown 文件，浏览器会自动刷新显示最新内容。\n\n### 调试技巧\n\n1. **检查控制台**：打开浏览器开发者工具查看错误\n2. **验证路径**：确保文件路径正确\n3. **清理缓存**：遇到问题时清理 `node_modules/.vite`\n\n## 第三步：组织文档结构\n\n### 推荐目录结构\n\n```\ndocs/\n├── getting-started/\n│   ├── README.md\n│   ├── installation.md\n│   └── quick-start.md\n├── guides/\n│   ├── README.md\n│   ├── basic-usage.md\n│   └── advanced-features.md\n├── api/\n│   ├── README.md\n│   ├── core-api.md\n│   └── utilities.md\n└── faq/\n    └── README.md\n```\n\n### 文件命名规范\n\n- 使用小写字母和连字符\n- `README.md` 作为目录首页\n- 描述性文件名：`user-authentication.md`\n\n### Frontmatter 最佳实践\n\n每个文档都应包含 frontmatter：\n\n```yaml\n---\ntitle: 页面标题\ndescription: 页面描述（用于 SEO）\nauthor: 作者名称\ndate: 2026-01-19\ntags: [tutorial, beginner]\n---\n```\n\n## 第四步：添加代码示例\n\n### 语法高亮\n\n使用语言标识符启用语法高亮：\n\n````markdown\n```javascript\nfunction hello() {\n  console.log('Hello, World!')\n}\n```\n\n```python\ndef hello():\n    print(\"Hello, World!\")\n```\n\n```bash\necho \"Hello, World!\"\n```\n````\n\n### 代码注释\n\n添加注释说明关键代码：\n\n```javascript\n// 初始化应用\nconst app = createApp()\n\n// 配置路由\napp.use(router)\n\n// 启动应用\napp.mount('#app')\n```\n\n### 可运行示例\n\n提供完整的可运行代码：\n\n```javascript\n// 完整示例：用户认证\nimport { authenticate } from './auth'\n\nasync function login(username, password) {\n  try {\n    const user = await authenticate(username, password)\n    console.log('登录成功:', user)\n    return user\n  } catch (error) {\n    console.error('登录失败:', error)\n    throw error\n  }\n}\n\n// 使用示例\nlogin('user@example.com', 'password123')\n```\n\n## 第五步：构建生产版本\n\n### 构建站点\n\n生成静态文件：\n\n```bash\ndocgen build --dir ./docs --output ./dist\n```\n\n### 验证构建\n\n预览构建后的站点：\n\n```bash\ndocgen preview --output ./dist\n```\n\n### 优化建议\n\n1. **压缩图片**：使用 WebP 格式\n2. **代码分割**：大型文档分成多个文件\n3. **缓存策略**：配置适当的缓存头\n\n## 第六步：部署上线\n\n### 部署到 Netlify\n\n1. 连接 Git 仓库\n2. 配置构建命令：`docgen build --dir ./docs --output ./dist`\n3. 设置发布目录：`dist`\n4. 点击部署\n\n### 部署到 Vercel\n\n```bash\nnpm install -g vercel\nvercel --prod\n```\n\n### 自定义域名\n\n在部署平台配置自定义域名：\n\n1. 添加 CNAME 记录\n2. 配置 SSL 证书\n3. 等待 DNS 生效\n\n## 常见问题\n\n### 样式不显示？\n\n清理缓存并重新构建：\n\n```bash\nrm -rf node_modules/.vite\ndocgen build --dir ./docs --output ./dist\n```\n\n### 路由 404 错误？\n\n确保服务器配置了 SPA 回退：\n\n```nginx\nlocation / {\n  try_files $uri $uri/ /index.html;\n}\n```\n\n### 搜索不工作？\n\n检查文件是否正确扫描：\n\n```bash\ndocgen build --dir ./docs --output ./dist --verbose\n```\n\n## 下一步\n\n- 阅读 [API 参考](../api/README.md)\n- 查看 [配置选项](../configuration/README.md)\n- 浏览 [FAQ](../faq/README.md)\n","frontmatter":{"title":"教程指南","description":"从零开始学习使用 DocGen","html":"<h1>教程指南</h1>\n<p>通过实际示例学习如何使用 DocGen 构建文档站点。</p>\n<h2>第一步：创建项目</h2>\n<h3>1. 安装 DocGen</h3>\n<p>首先安装 DocGen CLI 工具：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">npm</span><span style=\"color:#9ECBFF\"> install</span><span style=\"color:#79B8FF\"> -g</span><span style=\"color:#9ECBFF\"> docgen</span></span>\n<span class=\"line\"></span></code></pre>\n<p>验证安装：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">docgen</span><span style=\"color:#79B8FF\"> --version</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>2. 创建文档目录</h3>\n<p>创建你的文档项目结构：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">mkdir</span><span style=\"color:#9ECBFF\"> my-documentation</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">cd</span><span style=\"color:#9ECBFF\"> my-documentation</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">mkdir</span><span style=\"color:#9ECBFF\"> docs</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>3. 编写第一个文档</h3>\n<p>创建 <code>docs/getting-started/README.md</code>：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">---</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">title</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">快速开始</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">description</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">开始使用我们的产品</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">---</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#79B8FF;font-weight:bold\"># 快速开始</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">欢迎使用我们的产品！</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#79B8FF;font-weight:bold\">## 安装</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">\\`\\`\\`</span><span style=\"color:#E1E4E8\">bash</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">npm install my-product</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">\\`\\`\\`</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#79B8FF;font-weight:bold\">## 基本用法</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">\\`\\`\\`</span><span style=\"color:#E1E4E8\">javascript</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">import { MyProduct } from 'my-product'</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">const product = new MyProduct()</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">product.start()</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">\\`\\`\\`</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>第二步：启动开发服务器</h2>\n<h3>实时预览</h3>\n<p>启动开发服务器查看效果：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">docgen</span><span style=\"color:#9ECBFF\"> dev</span><span style=\"color:#79B8FF\"> --dir</span><span style=\"color:#9ECBFF\"> ./docs</span></span>\n<span class=\"line\"></span></code></pre>\n<p>访问 <code>http://localhost:3000</code> 查看你的文档站点。</p>\n<h3>热更新</h3>\n<p>修改任何 Markdown 文件，浏览器会自动刷新显示最新内容。</p>\n<h3>调试技巧</h3>\n<ol>\n<li><strong>检查控制台</strong>：打开浏览器开发者工具查看错误</li>\n<li><strong>验证路径</strong>：确保文件路径正确</li>\n<li><strong>清理缓存</strong>：遇到问题时清理 <code>node_modules/.vite</code></li>\n</ol>\n<h2>第三步：组织文档结构</h2>\n<h3>推荐目录结构</h3>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span>docs/</span></span>\n<span class=\"line\"><span>├── getting-started/</span></span>\n<span class=\"line\"><span>│   ├── README.md</span></span>\n<span class=\"line\"><span>│   ├── installation.md</span></span>\n<span class=\"line\"><span>│   └── quick-start.md</span></span>\n<span class=\"line\"><span>├── guides/</span></span>\n<span class=\"line\"><span>│   ├── README.md</span></span>\n<span class=\"line\"><span>│   ├── basic-usage.md</span></span>\n<span class=\"line\"><span>│   └── advanced-features.md</span></span>\n<span class=\"line\"><span>├── api/</span></span>\n<span class=\"line\"><span>│   ├── README.md</span></span>\n<span class=\"line\"><span>│   ├── core-api.md</span></span>\n<span class=\"line\"><span>│   └── utilities.md</span></span>\n<span class=\"line\"><span>└── faq/</span></span>\n<span class=\"line\"><span>    └── README.md</span></span>\n<span class=\"line\"><span></span></span></code></pre>\n<h3>文件命名规范</h3>\n<ul>\n<li>使用小写字母和连字符</li>\n<li><code>README.md</code> 作为目录首页</li>\n<li>描述性文件名：<code>user-authentication.md</code></li>\n</ul>\n<h3>Frontmatter 最佳实践</h3>\n<p>每个文档都应包含 frontmatter：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">---</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">title</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">页面标题</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">description</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">页面描述（用于 SEO）</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">author</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">作者名称</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">date</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">2026-01-19</span></span>\n<span class=\"line\"><span style=\"color:#85E89D\">tags</span><span style=\"color:#E1E4E8\">: [</span><span style=\"color:#9ECBFF\">tutorial</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#9ECBFF\">beginner</span><span style=\"color:#E1E4E8\">]</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">---</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>第四步：添加代码示例</h2>\n<h3>语法高亮</h3>\n<p>使用语言标识符启用语法高亮：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">```javascript</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">function</span><span style=\"color:#B392F0\"> hello</span><span style=\"color:#E1E4E8\">() {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  console.</span><span style=\"color:#B392F0\">log</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'Hello, World!'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">```</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">```python</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">def</span><span style=\"color:#B392F0\"> hello</span><span style=\"color:#E1E4E8\">():</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">    print</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">\"Hello, World!\"</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">```</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">```bash</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">echo</span><span style=\"color:#9ECBFF\"> \"Hello, World!\"</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">```</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>代码注释</h3>\n<p>添加注释说明关键代码：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#6A737D\">// 初始化应用</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#79B8FF\"> app</span><span style=\"color:#F97583\"> =</span><span style=\"color:#B392F0\"> createApp</span><span style=\"color:#E1E4E8\">()</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#6A737D\">// 配置路由</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">app.</span><span style=\"color:#B392F0\">use</span><span style=\"color:#E1E4E8\">(router)</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#6A737D\">// 启动应用</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">app.</span><span style=\"color:#B392F0\">mount</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'#app'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>可运行示例</h3>\n<p>提供完整的可运行代码：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#6A737D\">// 完整示例：用户认证</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#E1E4E8\"> { authenticate } </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> './auth'</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#F97583\">async</span><span style=\"color:#F97583\"> function</span><span style=\"color:#B392F0\"> login</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">username</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#FFAB70\">password</span><span style=\"color:#E1E4E8\">) {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">  try</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">    const</span><span style=\"color:#79B8FF\"> user</span><span style=\"color:#F97583\"> =</span><span style=\"color:#F97583\"> await</span><span style=\"color:#B392F0\"> authenticate</span><span style=\"color:#E1E4E8\">(username, password)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    console.</span><span style=\"color:#B392F0\">log</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'登录成功:'</span><span style=\"color:#E1E4E8\">, user)</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">    return</span><span style=\"color:#E1E4E8\"> user</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  } </span><span style=\"color:#F97583\">catch</span><span style=\"color:#E1E4E8\"> (error) {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    console.</span><span style=\"color:#B392F0\">error</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'登录失败:'</span><span style=\"color:#E1E4E8\">, error)</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">    throw</span><span style=\"color:#E1E4E8\"> error</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#6A737D\">// 使用示例</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">login</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'user@example.com'</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#9ECBFF\">'password123'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>第五步：构建生产版本</h2>\n<h3>构建站点</h3>\n<p>生成静态文件：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">docgen</span><span style=\"color:#9ECBFF\"> build</span><span style=\"color:#79B8FF\"> --dir</span><span style=\"color:#9ECBFF\"> ./docs</span><span style=\"color:#79B8FF\"> --output</span><span style=\"color:#9ECBFF\"> ./dist</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>验证构建</h3>\n<p>预览构建后的站点：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">docgen</span><span style=\"color:#9ECBFF\"> preview</span><span style=\"color:#79B8FF\"> --output</span><span style=\"color:#9ECBFF\"> ./dist</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>优化建议</h3>\n<ol>\n<li><strong>压缩图片</strong>：使用 WebP 格式</li>\n<li><strong>代码分割</strong>：大型文档分成多个文件</li>\n<li><strong>缓存策略</strong>：配置适当的缓存头</li>\n</ol>\n<h2>第六步：部署上线</h2>\n<h3>部署到 Netlify</h3>\n<ol>\n<li>连接 Git 仓库</li>\n<li>配置构建命令：<code>docgen build --dir ./docs --output ./dist</code></li>\n<li>设置发布目录：<code>dist</code></li>\n<li>点击部署</li>\n</ol>\n<h3>部署到 Vercel</h3>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">npm</span><span style=\"color:#9ECBFF\"> install</span><span style=\"color:#79B8FF\"> -g</span><span style=\"color:#9ECBFF\"> vercel</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">vercel</span><span style=\"color:#79B8FF\"> --prod</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>自定义域名</h3>\n<p>在部署平台配置自定义域名：</p>\n<ol>\n<li>添加 CNAME 记录</li>\n<li>配置 SSL 证书</li>\n<li>等待 DNS 生效</li>\n</ol>\n<h2>常见问题</h2>\n<h3>样式不显示？</h3>\n<p>清理缓存并重新构建：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">rm</span><span style=\"color:#79B8FF\"> -rf</span><span style=\"color:#9ECBFF\"> node_modules/.vite</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">docgen</span><span style=\"color:#9ECBFF\"> build</span><span style=\"color:#79B8FF\"> --dir</span><span style=\"color:#9ECBFF\"> ./docs</span><span style=\"color:#79B8FF\"> --output</span><span style=\"color:#9ECBFF\"> ./dist</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>路由 404 错误？</h3>\n<p>确保服务器配置了 SPA 回退：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span>location / {</span></span>\n<span class=\"line\"><span>  try_files $uri $uri/ /index.html;</span></span>\n<span class=\"line\"><span>}</span></span>\n<span class=\"line\"><span></span></span></code></pre>\n<h3>搜索不工作？</h3>\n<p>检查文件是否正确扫描：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#B392F0\">docgen</span><span style=\"color:#9ECBFF\"> build</span><span style=\"color:#79B8FF\"> --dir</span><span style=\"color:#9ECBFF\"> ./docs</span><span style=\"color:#79B8FF\"> --output</span><span style=\"color:#9ECBFF\"> ./dist</span><span style=\"color:#79B8FF\"> --verbose</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>下一步</h2>\n<ul>\n<li>阅读 <a href=\"../api/README.md\">API 参考</a></li>\n<li>查看 <a href=\"../configuration/README.md\">配置选项</a></li>\n<li>浏览 <a href=\"../faq/README.md\">FAQ</a></li>\n</ul>\n","headings":[]},"lastModified":1768789292382},{"path":"/Users/pan/docgen/my-docs/tutorials/customization.md","name":"customization.md","title":"自定义文档站点","description":"学习如何自定义 DocGen 文档站点的外观和功能","content":"\n# 自定义文档站点\n\n让你的文档站点与众不同。\n\n## 自定义样式\n\n### 修改颜色主题\n\n创建自定义 CSS 文件覆盖默认变量：\n\n```css\n/* custom.css */\n:root {\n  /* 主色调 */\n  --color-primary: #3b82f6;\n  --color-primary-foreground: #ffffff;\n  \n  /* 背景色 */\n  --color-background: #f9fafb;\n  --color-foreground: #111827;\n  \n  /* 强调色 */\n  --color-accent: #dbeafe;\n  --color-accent-foreground: #1e40af;\n  \n  /* 边框和分隔线 */\n  --color-border: #e5e7eb;\n  --color-muted: #f3f4f6;\n}\n```\n\n### 自定义字体\n\n使用 Google Fonts 或本地字体：\n\n```css\n@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');\n\n:root {\n  --font-sans: 'Inter', -apple-system, sans-serif;\n  --font-mono: 'Fira Code', monospace;\n}\n\nbody {\n  font-family: var(--font-sans);\n}\n\ncode, pre {\n  font-family: var(--font-mono);\n}\n```\n\n### 响应式断点\n\n自定义移动端和桌面端样式：\n\n```css\n/* 移动端 */\n@media (max-width: 768px) {\n  .container {\n    padding: 0 1rem;\n  }\n  \n  .sidebar {\n    transform: translateX(-100%);\n  }\n}\n\n/* 平板 */\n@media (min-width: 769px) and (max-width: 1024px) {\n  .container {\n    max-width: 720px;\n  }\n}\n\n/* 桌面端 */\n@media (min-width: 1025px) {\n  .container {\n    max-width: 1200px;\n  }\n}\n```\n\n## 自定义组件\n\n### 添加自定义 Logo\n\n替换默认 Logo：\n\n```html\n<!-- 在 index.html 中 -->\n<div class=\"logo\">\n  <img src=\"/logo.svg\" alt=\"My Docs\" />\n  <span>My Documentation</span>\n</div>\n```\n\n### 自定义导航栏\n\n添加额外的导航链接：\n\n```vue\n<template>\n  <header class=\"header\">\n    <nav class=\"nav\">\n      <a href=\"/\">首页</a>\n      <a href=\"/docs\">文档</a>\n      <a href=\"/blog\">博客</a>\n      <a href=\"/about\">关于</a>\n    </nav>\n  </header>\n</template>\n```\n\n### 添加页脚\n\n创建自定义页脚组件：\n\n```vue\n<template>\n  <footer class=\"footer\">\n    <div class=\"footer-content\">\n      <div class=\"footer-section\">\n        <h3>产品</h3>\n        <ul>\n          <li><a href=\"/features\">功能特性</a></li>\n          <li><a href=\"/pricing\">价格方案</a></li>\n          <li><a href=\"/roadmap\">产品路线图</a></li>\n        </ul>\n      </div>\n      \n      <div class=\"footer-section\">\n        <h3>资源</h3>\n        <ul>\n          <li><a href=\"/docs\">文档</a></li>\n          <li><a href=\"/api\">API 参考</a></li>\n          <li><a href=\"/examples\">示例代码</a></li>\n        </ul>\n      </div>\n      \n      <div class=\"footer-section\">\n        <h3>社区</h3>\n        <ul>\n          <li><a href=\"/blog\">博客</a></li>\n          <li><a href=\"/forum\">论坛</a></li>\n          <li><a href=\"/discord\">Discord</a></li>\n        </ul>\n      </div>\n    </div>\n    \n    <div class=\"footer-bottom\">\n      <p>&copy; 2026 Your Company. All rights reserved.</p>\n    </div>\n  </footer>\n</template>\n\n<style scoped>\n.footer {\n  background: var(--color-muted);\n  border-top: 1px solid var(--color-border);\n  padding: 3rem 0 1rem;\n  margin-top: 4rem;\n}\n\n.footer-content {\n  display: grid;\n  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));\n  gap: 2rem;\n  max-width: 1200px;\n  margin: 0 auto;\n  padding: 0 2rem;\n}\n\n.footer-section h3 {\n  font-size: 0.875rem;\n  font-weight: 600;\n  margin-bottom: 1rem;\n  text-transform: uppercase;\n  letter-spacing: 0.05em;\n}\n\n.footer-section ul {\n  list-style: none;\n  padding: 0;\n}\n\n.footer-section li {\n  margin-bottom: 0.5rem;\n}\n\n.footer-section a {\n  color: var(--color-muted-foreground);\n  text-decoration: none;\n  font-size: 0.875rem;\n}\n\n.footer-section a:hover {\n  color: var(--color-primary);\n}\n\n.footer-bottom {\n  text-align: center;\n  margin-top: 2rem;\n  padding-top: 2rem;\n  border-top: 1px solid var(--color-border);\n  color: var(--color-muted-foreground);\n  font-size: 0.875rem;\n}\n</style>\n```\n\n## 自定义 Markdown 渲染\n\n### 添加自定义容器\n\n支持警告、提示等容器：\n\n```markdown\n::: warning\n这是一个警告信息\n:::\n\n::: tip\n这是一个提示信息\n:::\n\n::: danger\n这是一个危险警告\n:::\n```\n\n实现自定义容器：\n\n```typescript\nimport MarkdownIt from 'markdown-it'\nimport container from 'markdown-it-container'\n\nconst md = new MarkdownIt()\n  .use(container, 'warning', {\n    render: (tokens, idx) => {\n      if (tokens[idx].nesting === 1) {\n        return '<div class=\"warning\">\\n'\n      } else {\n        return '</div>\\n'\n      }\n    }\n  })\n  .use(container, 'tip', {\n    render: (tokens, idx) => {\n      if (tokens[idx].nesting === 1) {\n        return '<div class=\"tip\">\\n'\n      } else {\n        return '</div>\\n'\n      }\n    }\n  })\n```\n\n### 代码块增强\n\n添加复制按钮和行号：\n\n```typescript\nmd.renderer.rules.fence = (tokens, idx) => {\n  const token = tokens[idx]\n  const lang = token.info.trim()\n  const code = token.content\n  \n  return `\n    <div class=\"code-block\">\n      <div class=\"code-header\">\n        <span class=\"language\">${lang}</span>\n        <button class=\"copy-button\" onclick=\"copyCode(this)\">\n          复制\n        </button>\n      </div>\n      <pre><code class=\"language-${lang}\">${escapeHtml(code)}</code></pre>\n    </div>\n  `\n}\n```\n\n### 自动链接标题\n\n为所有标题添加锚点链接：\n\n```typescript\nimport anchor from 'markdown-it-anchor'\n\nmd.use(anchor, {\n  permalink: true,\n  permalinkBefore: true,\n  permalinkSymbol: '#',\n  permalinkClass: 'header-anchor'\n})\n```\n\n## 添加交互功能\n\n### 代码复制功能\n\n```javascript\nfunction copyCode(button) {\n  const codeBlock = button.closest('.code-block')\n  const code = codeBlock.querySelector('code').textContent\n  \n  navigator.clipboard.writeText(code).then(() => {\n    button.textContent = '已复制!'\n    setTimeout(() => {\n      button.textContent = '复制'\n    }, 2000)\n  })\n}\n```\n\n### 目录高亮\n\n滚动时高亮当前章节：\n\n```javascript\nconst observer = new IntersectionObserver((entries) => {\n  entries.forEach(entry => {\n    if (entry.isIntersecting) {\n      const id = entry.target.id\n      document.querySelectorAll('.toc-link').forEach(link => {\n        link.classList.remove('active')\n      })\n      document.querySelector(`a[href=\"#${id}\"]`)?.classList.add('active')\n    }\n  })\n}, {\n  rootMargin: '-100px 0px -80% 0px'\n})\n\ndocument.querySelectorAll('h2, h3').forEach(heading => {\n  observer.observe(heading)\n})\n```\n\n### 深色模式切换\n\n添加手动切换深色模式：\n\n```vue\n<template>\n  <button @click=\"toggleDarkMode\" class=\"theme-toggle\">\n    <span v-if=\"isDark\">🌞</span>\n    <span v-else>🌙</span>\n  </button>\n</template>\n\n<script setup>\nimport { ref, onMounted } from 'vue'\n\nconst isDark = ref(false)\n\nonMounted(() => {\n  isDark.value = localStorage.getItem('theme') === 'dark'\n  applyTheme()\n})\n\nfunction toggleDarkMode() {\n  isDark.value = !isDark.value\n  localStorage.setItem('theme', isDark.value ? 'dark' : 'light')\n  applyTheme()\n}\n\nfunction applyTheme() {\n  if (isDark.value) {\n    document.documentElement.classList.add('dark')\n  } else {\n    document.documentElement.classList.remove('dark')\n  }\n}\n</script>\n```\n\n## 集成第三方服务\n\n### 添加评论系统\n\n使用 Giscus：\n\n```html\n<script src=\"https://giscus.app/client.js\"\n        data-repo=\"your-username/your-repo\"\n        data-repo-id=\"your-repo-id\"\n        data-category=\"Announcements\"\n        data-category-id=\"your-category-id\"\n        data-mapping=\"pathname\"\n        data-reactions-enabled=\"1\"\n        data-emit-metadata=\"0\"\n        data-input-position=\"bottom\"\n        data-theme=\"light\"\n        data-lang=\"zh-CN\"\n        crossorigin=\"anonymous\"\n        async>\n</script>\n```\n\n### 添加搜索功能\n\n集成 Algolia DocSearch：\n\n```html\n<link rel=\"stylesheet\" href=\"https://cdn.jsdelivr.net/npm/@docsearch/css@3\" />\n\n<script src=\"https://cdn.jsdelivr.net/npm/@docsearch/js@3\"></script>\n<script>\n  docsearch({\n    appId: 'YOUR_APP_ID',\n    apiKey: 'YOUR_API_KEY',\n    indexName: 'YOUR_INDEX_NAME',\n    container: '#docsearch',\n  })\n</script>\n```\n\n### 添加分析统计\n\nGoogle Analytics 4：\n\n```html\n<script async src=\"https://www.googletagmanager.com/gtag/js?id=G-XXXXXXXXXX\"></script>\n<script>\n  window.dataLayer = window.dataLayer || [];\n  function gtag(){dataLayer.push(arguments);}\n  gtag('js', new Date());\n  gtag('config', 'G-XXXXXXXXXX');\n</script>\n```\n\n## 性能优化\n\n### 图片懒加载\n\n```html\n<img src=\"placeholder.jpg\" \n     data-src=\"actual-image.jpg\" \n     loading=\"lazy\" \n     alt=\"描述\">\n```\n\n### 预加载关键资源\n\n```html\n<link rel=\"preload\" href=\"/fonts/inter.woff2\" as=\"font\" type=\"font/woff2\" crossorigin>\n<link rel=\"preload\" href=\"/critical.css\" as=\"style\">\n```\n\n### Service Worker 缓存\n\n```javascript\n// service-worker.js\nself.addEventListener('install', (event) => {\n  event.waitUntil(\n    caches.open('docs-v1').then((cache) => {\n      return cache.addAll([\n        '/',\n        '/index.html',\n        '/assets/main.css',\n        '/assets/main.js'\n      ])\n    })\n  )\n})\n\nself.addEventListener('fetch', (event) => {\n  event.respondWith(\n    caches.match(event.request).then((response) => {\n      return response || fetch(event.request)\n    })\n  )\n})\n```\n\n## 总结\n\n通过这些自定义选项，你可以：\n\n- ✅ 创建独特的视觉风格\n- ✅ 添加自定义功能组件\n- ✅ 增强 Markdown 渲染\n- ✅ 集成第三方服务\n- ✅ 优化性能和用户体验\n\n继续探索更多可能性！\n","frontmatter":{"title":"自定义文档站点","description":"学习如何自定义 DocGen 文档站点的外观和功能","html":"<h1>自定义文档站点</h1>\n<p>让你的文档站点与众不同。</p>\n<h2>自定义样式</h2>\n<h3>修改颜色主题</h3>\n<p>创建自定义 CSS 文件覆盖默认变量：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#6A737D\">/* custom.css */</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">:root</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#6A737D\">  /* 主色调 */</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --color-primary</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">#3b82f6</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --color-primary-foreground</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">#ffffff</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  </span></span>\n<span class=\"line\"><span style=\"color:#6A737D\">  /* 背景色 */</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --color-background</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">#f9fafb</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --color-foreground</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">#111827</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  </span></span>\n<span class=\"line\"><span style=\"color:#6A737D\">  /* 强调色 */</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --color-accent</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">#dbeafe</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --color-accent-foreground</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">#1e40af</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  </span></span>\n<span class=\"line\"><span style=\"color:#6A737D\">  /* 边框和分隔线 */</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --color-border</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">#e5e7eb</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --color-muted</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">#f3f4f6</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>自定义字体</h3>\n<p>使用 Google Fonts 或本地字体：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">@import</span><span style=\"color:#79B8FF\"> url</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&#x26;display=swap'</span><span style=\"color:#E1E4E8\">);</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#B392F0\">:root</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --font-sans</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">'Inter'</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#79B8FF\">-apple-system</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#79B8FF\">sans-serif</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#FFAB70\">  --font-mono</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#9ECBFF\">'Fira Code'</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#79B8FF\">monospace</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#85E89D\">body</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  font-family</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">var</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">--font-sans</span><span style=\"color:#E1E4E8\">);</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#85E89D\">code</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#85E89D\">pre</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  font-family</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">var</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">--font-mono</span><span style=\"color:#E1E4E8\">);</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>响应式断点</h3>\n<p>自定义移动端和桌面端样式：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#6A737D\">/* 移动端 */</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">@media</span><span style=\"color:#E1E4E8\"> (</span><span style=\"color:#79B8FF\">max-width</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">768</span><span style=\"color:#F97583\">px</span><span style=\"color:#E1E4E8\">) {</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">  .container</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">    padding</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">0</span><span style=\"color:#79B8FF\"> 1</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  </span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">  .sidebar</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">    transform</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">translateX</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#79B8FF\">-100</span><span style=\"color:#F97583\">%</span><span style=\"color:#E1E4E8\">);</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#6A737D\">/* 平板 */</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">@media</span><span style=\"color:#E1E4E8\"> (</span><span style=\"color:#79B8FF\">min-width</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">769</span><span style=\"color:#F97583\">px</span><span style=\"color:#E1E4E8\">) </span><span style=\"color:#F97583\">and</span><span style=\"color:#E1E4E8\"> (</span><span style=\"color:#79B8FF\">max-width</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">1024</span><span style=\"color:#F97583\">px</span><span style=\"color:#E1E4E8\">) {</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">  .container</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">    max-width</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">720</span><span style=\"color:#F97583\">px</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#6A737D\">/* 桌面端 */</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">@media</span><span style=\"color:#E1E4E8\"> (</span><span style=\"color:#79B8FF\">min-width</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">1025</span><span style=\"color:#F97583\">px</span><span style=\"color:#E1E4E8\">) {</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">  .container</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">    max-width</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">1200</span><span style=\"color:#F97583\">px</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>自定义组件</h2>\n<h3>添加自定义 Logo</h3>\n<p>替换默认 Logo：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#6A737D\">&#x3C;!-- 在 index.html 中 --></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">div</span><span style=\"color:#B392F0\"> class</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"logo\"</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  &#x3C;</span><span style=\"color:#85E89D\">img</span><span style=\"color:#B392F0\"> src</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/logo.svg\"</span><span style=\"color:#B392F0\"> alt</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"My Docs\"</span><span style=\"color:#E1E4E8\"> /></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  &#x3C;</span><span style=\"color:#85E89D\">span</span><span style=\"color:#E1E4E8\">>My Documentation&#x3C;/</span><span style=\"color:#85E89D\">span</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;/</span><span style=\"color:#85E89D\">div</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span></code></pre>\n<h3>自定义导航栏</h3>\n<p>添加额外的导航链接：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">template</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  &#x3C;</span><span style=\"color:#85E89D\">header</span><span style=\"color:#B392F0\"> class</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"header\"</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    &#x3C;</span><span style=\"color:#85E89D\">nav</span><span style=\"color:#B392F0\"> class</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"nav\"</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      &#x3C;</span><span style=\"color:#85E89D\">a</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/\"</span><span style=\"color:#E1E4E8\">>首页&#x3C;/</span><span style=\"color:#85E89D\">a</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      &#x3C;</span><span style=\"color:#85E89D\">a</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/docs\"</span><span style=\"color:#E1E4E8\">>文档&#x3C;/</span><span style=\"color:#85E89D\">a</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      &#x3C;</span><span style=\"color:#85E89D\">a</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/blog\"</span><span style=\"color:#E1E4E8\">>博客&#x3C;/</span><span style=\"color:#85E89D\">a</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      &#x3C;</span><span style=\"color:#85E89D\">a</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/about\"</span><span style=\"color:#E1E4E8\">>关于&#x3C;/</span><span style=\"color:#85E89D\">a</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    &#x3C;/</span><span style=\"color:#85E89D\">nav</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  &#x3C;/</span><span style=\"color:#85E89D\">header</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;/</span><span style=\"color:#85E89D\">template</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span></code></pre>\n<h3>添加页脚</h3>\n<p>创建自定义页脚组件：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">template</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  &#x3C;</span><span style=\"color:#85E89D\">footer</span><span style=\"color:#B392F0\"> class</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"footer\"</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    &#x3C;</span><span style=\"color:#85E89D\">div</span><span style=\"color:#B392F0\"> class</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"footer-content\"</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      &#x3C;</span><span style=\"color:#85E89D\">div</span><span style=\"color:#B392F0\"> class</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"footer-section\"</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">        &#x3C;</span><span style=\"color:#85E89D\">h3</span><span style=\"color:#E1E4E8\">>产品&#x3C;/</span><span style=\"color:#85E89D\">h3</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">        &#x3C;</span><span style=\"color:#85E89D\">ul</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">          &#x3C;</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">>&#x3C;</span><span style=\"color:#85E89D\">a</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/features\"</span><span style=\"color:#E1E4E8\">>功能特性&#x3C;/</span><span style=\"color:#85E89D\">a</span><span style=\"color:#E1E4E8\">>&#x3C;/</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">          &#x3C;</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">>&#x3C;</span><span style=\"color:#85E89D\">a</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/pricing\"</span><span style=\"color:#E1E4E8\">>价格方案&#x3C;/</span><span style=\"color:#85E89D\">a</span><span style=\"color:#E1E4E8\">>&#x3C;/</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">          &#x3C;</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">>&#x3C;</span><span style=\"color:#85E89D\">a</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/roadmap\"</span><span style=\"color:#E1E4E8\">>产品路线图&#x3C;/</span><span style=\"color:#85E89D\">a</span><span style=\"color:#E1E4E8\">>&#x3C;/</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">        &#x3C;/</span><span style=\"color:#85E89D\">ul</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      &#x3C;/</span><span style=\"color:#85E89D\">div</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      </span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      &#x3C;</span><span style=\"color:#85E89D\">div</span><span style=\"color:#B392F0\"> class</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"footer-section\"</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">        &#x3C;</span><span style=\"color:#85E89D\">h3</span><span style=\"color:#E1E4E8\">>资源&#x3C;/</span><span style=\"color:#85E89D\">h3</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">        &#x3C;</span><span style=\"color:#85E89D\">ul</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">          &#x3C;</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">>&#x3C;</span><span style=\"color:#85E89D\">a</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/docs\"</span><span style=\"color:#E1E4E8\">>文档&#x3C;/</span><span style=\"color:#85E89D\">a</span><span style=\"color:#E1E4E8\">>&#x3C;/</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">          &#x3C;</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">>&#x3C;</span><span style=\"color:#85E89D\">a</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/api\"</span><span style=\"color:#E1E4E8\">>API 参考&#x3C;/</span><span style=\"color:#85E89D\">a</span><span style=\"color:#E1E4E8\">>&#x3C;/</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">          &#x3C;</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">>&#x3C;</span><span style=\"color:#85E89D\">a</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/examples\"</span><span style=\"color:#E1E4E8\">>示例代码&#x3C;/</span><span style=\"color:#85E89D\">a</span><span style=\"color:#E1E4E8\">>&#x3C;/</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">        &#x3C;/</span><span style=\"color:#85E89D\">ul</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      &#x3C;/</span><span style=\"color:#85E89D\">div</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      </span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      &#x3C;</span><span style=\"color:#85E89D\">div</span><span style=\"color:#B392F0\"> class</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"footer-section\"</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">        &#x3C;</span><span style=\"color:#85E89D\">h3</span><span style=\"color:#E1E4E8\">>社区&#x3C;/</span><span style=\"color:#85E89D\">h3</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">        &#x3C;</span><span style=\"color:#85E89D\">ul</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">          &#x3C;</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">>&#x3C;</span><span style=\"color:#85E89D\">a</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/blog\"</span><span style=\"color:#E1E4E8\">>博客&#x3C;/</span><span style=\"color:#85E89D\">a</span><span style=\"color:#E1E4E8\">>&#x3C;/</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">          &#x3C;</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">>&#x3C;</span><span style=\"color:#85E89D\">a</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/forum\"</span><span style=\"color:#E1E4E8\">>论坛&#x3C;/</span><span style=\"color:#85E89D\">a</span><span style=\"color:#E1E4E8\">>&#x3C;/</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">          &#x3C;</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">>&#x3C;</span><span style=\"color:#85E89D\">a</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/discord\"</span><span style=\"color:#E1E4E8\">>Discord&#x3C;/</span><span style=\"color:#85E89D\">a</span><span style=\"color:#E1E4E8\">>&#x3C;/</span><span style=\"color:#85E89D\">li</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">        &#x3C;/</span><span style=\"color:#85E89D\">ul</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      &#x3C;/</span><span style=\"color:#85E89D\">div</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    &#x3C;/</span><span style=\"color:#85E89D\">div</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    </span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    &#x3C;</span><span style=\"color:#85E89D\">div</span><span style=\"color:#B392F0\"> class</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"footer-bottom\"</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      &#x3C;</span><span style=\"color:#85E89D\">p</span><span style=\"color:#E1E4E8\">></span><span style=\"color:#79B8FF\">&#x26;copy;</span><span style=\"color:#E1E4E8\"> 2026 Your Company. All rights reserved.&#x3C;/</span><span style=\"color:#85E89D\">p</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    &#x3C;/</span><span style=\"color:#85E89D\">div</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  &#x3C;/</span><span style=\"color:#85E89D\">footer</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;/</span><span style=\"color:#85E89D\">template</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">style</span><span style=\"color:#B392F0\"> scoped</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">.footer</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  background</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">var</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">--color-muted</span><span style=\"color:#E1E4E8\">);</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  border-top</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">1</span><span style=\"color:#F97583\">px</span><span style=\"color:#79B8FF\"> solid</span><span style=\"color:#79B8FF\"> var</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">--color-border</span><span style=\"color:#E1E4E8\">);</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  padding</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">3</span><span style=\"color:#F97583\">rem</span><span style=\"color:#79B8FF\"> 0</span><span style=\"color:#79B8FF\"> 1</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  margin-top</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">4</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#B392F0\">.footer-content</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  display</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">grid</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  grid-template-columns</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">repeat</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#79B8FF\">auto-fit</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#79B8FF\">minmax</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#79B8FF\">200</span><span style=\"color:#F97583\">px</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#79B8FF\">1</span><span style=\"color:#F97583\">fr</span><span style=\"color:#E1E4E8\">));</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  gap</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">2</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  max-width</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">1200</span><span style=\"color:#F97583\">px</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  margin</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">0</span><span style=\"color:#79B8FF\"> auto</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  padding</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">0</span><span style=\"color:#79B8FF\"> 2</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#B392F0\">.footer-section</span><span style=\"color:#85E89D\"> h3</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  font-size</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">0.875</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  font-weight</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">600</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  margin-bottom</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">1</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  text-transform</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">uppercase</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  letter-spacing</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">0.05</span><span style=\"color:#F97583\">em</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#B392F0\">.footer-section</span><span style=\"color:#85E89D\"> ul</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  list-style</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">none</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  padding</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">0</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#B392F0\">.footer-section</span><span style=\"color:#85E89D\"> li</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  margin-bottom</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">0.5</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#B392F0\">.footer-section</span><span style=\"color:#85E89D\"> a</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  color</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">var</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">--color-muted-foreground</span><span style=\"color:#E1E4E8\">);</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  text-decoration</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">none</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  font-size</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">0.875</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#B392F0\">.footer-section</span><span style=\"color:#85E89D\"> a</span><span style=\"color:#B392F0\">:hover</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  color</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">var</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">--color-primary</span><span style=\"color:#E1E4E8\">);</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#B392F0\">.footer-bottom</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  text-align</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">center</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  margin-top</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">2</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  padding-top</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">2</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  border-top</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">1</span><span style=\"color:#F97583\">px</span><span style=\"color:#79B8FF\"> solid</span><span style=\"color:#79B8FF\"> var</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">--color-border</span><span style=\"color:#E1E4E8\">);</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  color</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">var</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">--color-muted-foreground</span><span style=\"color:#E1E4E8\">);</span></span>\n<span class=\"line\"><span style=\"color:#79B8FF\">  font-size</span><span style=\"color:#E1E4E8\">: </span><span style=\"color:#79B8FF\">0.875</span><span style=\"color:#F97583\">rem</span><span style=\"color:#E1E4E8\">;</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;/</span><span style=\"color:#85E89D\">style</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span></code></pre>\n<h2>自定义 Markdown 渲染</h2>\n<h3>添加自定义容器</h3>\n<p>支持警告、提示等容器：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">::: warning</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">这是一个警告信息</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">:::</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">::: tip</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">这是一个提示信息</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">:::</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">::: danger</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">这是一个危险警告</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">:::</span></span>\n<span class=\"line\"></span></code></pre>\n<p>实现自定义容器：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#E1E4E8\"> MarkdownIt </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> 'markdown-it'</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#E1E4E8\"> container </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> 'markdown-it-container'</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#79B8FF\"> md</span><span style=\"color:#F97583\"> =</span><span style=\"color:#F97583\"> new</span><span style=\"color:#B392F0\"> MarkdownIt</span><span style=\"color:#E1E4E8\">()</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  .</span><span style=\"color:#B392F0\">use</span><span style=\"color:#E1E4E8\">(container, </span><span style=\"color:#9ECBFF\">'warning'</span><span style=\"color:#E1E4E8\">, {</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">    render</span><span style=\"color:#E1E4E8\">: (</span><span style=\"color:#FFAB70\">tokens</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#FFAB70\">idx</span><span style=\"color:#E1E4E8\">) </span><span style=\"color:#F97583\">=></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">      if</span><span style=\"color:#E1E4E8\"> (tokens[idx].nesting </span><span style=\"color:#F97583\">===</span><span style=\"color:#79B8FF\"> 1</span><span style=\"color:#E1E4E8\">) {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">        return</span><span style=\"color:#9ECBFF\"> '&#x3C;div class=\"warning\"></span><span style=\"color:#79B8FF\">\\n</span><span style=\"color:#9ECBFF\">'</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      } </span><span style=\"color:#F97583\">else</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">        return</span><span style=\"color:#9ECBFF\"> '&#x3C;/div></span><span style=\"color:#79B8FF\">\\n</span><span style=\"color:#9ECBFF\">'</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  })</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  .</span><span style=\"color:#B392F0\">use</span><span style=\"color:#E1E4E8\">(container, </span><span style=\"color:#9ECBFF\">'tip'</span><span style=\"color:#E1E4E8\">, {</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">    render</span><span style=\"color:#E1E4E8\">: (</span><span style=\"color:#FFAB70\">tokens</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#FFAB70\">idx</span><span style=\"color:#E1E4E8\">) </span><span style=\"color:#F97583\">=></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">      if</span><span style=\"color:#E1E4E8\"> (tokens[idx].nesting </span><span style=\"color:#F97583\">===</span><span style=\"color:#79B8FF\"> 1</span><span style=\"color:#E1E4E8\">) {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">        return</span><span style=\"color:#9ECBFF\"> '&#x3C;div class=\"tip\"></span><span style=\"color:#79B8FF\">\\n</span><span style=\"color:#9ECBFF\">'</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      } </span><span style=\"color:#F97583\">else</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">        return</span><span style=\"color:#9ECBFF\"> '&#x3C;/div></span><span style=\"color:#79B8FF\">\\n</span><span style=\"color:#9ECBFF\">'</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  })</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>代码块增强</h3>\n<p>添加复制按钮和行号：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">md.renderer.rules.</span><span style=\"color:#B392F0\">fence</span><span style=\"color:#F97583\"> =</span><span style=\"color:#E1E4E8\"> (</span><span style=\"color:#FFAB70\">tokens</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#FFAB70\">idx</span><span style=\"color:#E1E4E8\">) </span><span style=\"color:#F97583\">=></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">  const</span><span style=\"color:#79B8FF\"> token</span><span style=\"color:#F97583\"> =</span><span style=\"color:#E1E4E8\"> tokens[idx]</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">  const</span><span style=\"color:#79B8FF\"> lang</span><span style=\"color:#F97583\"> =</span><span style=\"color:#E1E4E8\"> token.info.</span><span style=\"color:#B392F0\">trim</span><span style=\"color:#E1E4E8\">()</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">  const</span><span style=\"color:#79B8FF\"> code</span><span style=\"color:#F97583\"> =</span><span style=\"color:#E1E4E8\"> token.content</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  </span></span>\n<span class=\"line\"><span style=\"color:#F97583\">  return</span><span style=\"color:#9ECBFF\"> `</span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">    &#x3C;div class=\"code-block\"></span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">      &#x3C;div class=\"code-header\"></span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">        &#x3C;span class=\"language\">${</span><span style=\"color:#E1E4E8\">lang</span><span style=\"color:#9ECBFF\">}&#x3C;/span></span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">        &#x3C;button class=\"copy-button\" onclick=\"copyCode(this)\"></span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">          复制</span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">        &#x3C;/button></span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">      &#x3C;/div></span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">      &#x3C;pre>&#x3C;code class=\"language-${</span><span style=\"color:#E1E4E8\">lang</span><span style=\"color:#9ECBFF\">}\">${</span><span style=\"color:#B392F0\">escapeHtml</span><span style=\"color:#9ECBFF\">(</span><span style=\"color:#E1E4E8\">code</span><span style=\"color:#9ECBFF\">)</span><span style=\"color:#9ECBFF\">}&#x3C;/code>&#x3C;/pre></span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">    &#x3C;/div></span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">  `</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>自动链接标题</h3>\n<p>为所有标题添加锚点链接：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#E1E4E8\"> anchor </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> 'markdown-it-anchor'</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">md.</span><span style=\"color:#B392F0\">use</span><span style=\"color:#E1E4E8\">(anchor, {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  permalink: </span><span style=\"color:#79B8FF\">true</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  permalinkBefore: </span><span style=\"color:#79B8FF\">true</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  permalinkSymbol: </span><span style=\"color:#9ECBFF\">'#'</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  permalinkClass: </span><span style=\"color:#9ECBFF\">'header-anchor'</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">})</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>添加交互功能</h2>\n<h3>代码复制功能</h3>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">function</span><span style=\"color:#B392F0\"> copyCode</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">button</span><span style=\"color:#E1E4E8\">) {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">  const</span><span style=\"color:#79B8FF\"> codeBlock</span><span style=\"color:#F97583\"> =</span><span style=\"color:#E1E4E8\"> button.</span><span style=\"color:#B392F0\">closest</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'.code-block'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">  const</span><span style=\"color:#79B8FF\"> code</span><span style=\"color:#F97583\"> =</span><span style=\"color:#E1E4E8\"> codeBlock.</span><span style=\"color:#B392F0\">querySelector</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'code'</span><span style=\"color:#E1E4E8\">).textContent</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  </span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  navigator.clipboard.</span><span style=\"color:#B392F0\">writeText</span><span style=\"color:#E1E4E8\">(code).</span><span style=\"color:#B392F0\">then</span><span style=\"color:#E1E4E8\">(() </span><span style=\"color:#F97583\">=></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    button.textContent </span><span style=\"color:#F97583\">=</span><span style=\"color:#9ECBFF\"> '已复制!'</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">    setTimeout</span><span style=\"color:#E1E4E8\">(() </span><span style=\"color:#F97583\">=></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      button.textContent </span><span style=\"color:#F97583\">=</span><span style=\"color:#9ECBFF\"> '复制'</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    }, </span><span style=\"color:#79B8FF\">2000</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  })</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>目录高亮</h3>\n<p>滚动时高亮当前章节：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#79B8FF\"> observer</span><span style=\"color:#F97583\"> =</span><span style=\"color:#F97583\"> new</span><span style=\"color:#B392F0\"> IntersectionObserver</span><span style=\"color:#E1E4E8\">((</span><span style=\"color:#FFAB70\">entries</span><span style=\"color:#E1E4E8\">) </span><span style=\"color:#F97583\">=></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  entries.</span><span style=\"color:#B392F0\">forEach</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">entry</span><span style=\"color:#F97583\"> =></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">    if</span><span style=\"color:#E1E4E8\"> (entry.isIntersecting) {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">      const</span><span style=\"color:#79B8FF\"> id</span><span style=\"color:#F97583\"> =</span><span style=\"color:#E1E4E8\"> entry.target.id</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      document.</span><span style=\"color:#B392F0\">querySelectorAll</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'.toc-link'</span><span style=\"color:#E1E4E8\">).</span><span style=\"color:#B392F0\">forEach</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">link</span><span style=\"color:#F97583\"> =></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">        link.classList.</span><span style=\"color:#B392F0\">remove</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'active'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      })</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      document.</span><span style=\"color:#B392F0\">querySelector</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">`a[href=\"#${</span><span style=\"color:#E1E4E8\">id</span><span style=\"color:#9ECBFF\">}\"]`</span><span style=\"color:#E1E4E8\">)?.classList.</span><span style=\"color:#B392F0\">add</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'active'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  })</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}, {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  rootMargin: </span><span style=\"color:#9ECBFF\">'-100px 0px -80% 0px'</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">})</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">document.</span><span style=\"color:#B392F0\">querySelectorAll</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'h2, h3'</span><span style=\"color:#E1E4E8\">).</span><span style=\"color:#B392F0\">forEach</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#FFAB70\">heading</span><span style=\"color:#F97583\"> =></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  observer.</span><span style=\"color:#B392F0\">observe</span><span style=\"color:#E1E4E8\">(heading)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">})</span></span>\n<span class=\"line\"></span></code></pre>\n<h3>深色模式切换</h3>\n<p>添加手动切换深色模式：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">template</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  &#x3C;</span><span style=\"color:#85E89D\">button</span><span style=\"color:#B392F0\"> @click</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"toggleDarkMode\"</span><span style=\"color:#B392F0\"> class</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"theme-toggle\"</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    &#x3C;</span><span style=\"color:#85E89D\">span</span><span style=\"color:#B392F0\"> v-if</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"isDark\"</span><span style=\"color:#E1E4E8\">>🌞&#x3C;/</span><span style=\"color:#85E89D\">span</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    &#x3C;</span><span style=\"color:#85E89D\">span</span><span style=\"color:#B392F0\"> v-else</span><span style=\"color:#E1E4E8\">>🌙&#x3C;/</span><span style=\"color:#85E89D\">span</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  &#x3C;/</span><span style=\"color:#85E89D\">button</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;/</span><span style=\"color:#85E89D\">template</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">script</span><span style=\"color:#B392F0\"> setup</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#F97583\">import</span><span style=\"color:#E1E4E8\"> { ref, onMounted } </span><span style=\"color:#F97583\">from</span><span style=\"color:#9ECBFF\"> 'vue'</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#F97583\">const</span><span style=\"color:#79B8FF\"> isDark</span><span style=\"color:#F97583\"> =</span><span style=\"color:#B392F0\"> ref</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#79B8FF\">false</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#B392F0\">onMounted</span><span style=\"color:#E1E4E8\">(() </span><span style=\"color:#F97583\">=></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  isDark.value </span><span style=\"color:#F97583\">=</span><span style=\"color:#E1E4E8\"> localStorage.</span><span style=\"color:#B392F0\">getItem</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'theme'</span><span style=\"color:#E1E4E8\">) </span><span style=\"color:#F97583\">===</span><span style=\"color:#9ECBFF\"> 'dark'</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">  applyTheme</span><span style=\"color:#E1E4E8\">()</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">})</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#F97583\">function</span><span style=\"color:#B392F0\"> toggleDarkMode</span><span style=\"color:#E1E4E8\">() {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  isDark.value </span><span style=\"color:#F97583\">=</span><span style=\"color:#F97583\"> !</span><span style=\"color:#E1E4E8\">isDark.value</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  localStorage.</span><span style=\"color:#B392F0\">setItem</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'theme'</span><span style=\"color:#E1E4E8\">, isDark.value </span><span style=\"color:#F97583\">?</span><span style=\"color:#9ECBFF\"> 'dark'</span><span style=\"color:#F97583\"> :</span><span style=\"color:#9ECBFF\"> 'light'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">  applyTheme</span><span style=\"color:#E1E4E8\">()</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#F97583\">function</span><span style=\"color:#B392F0\"> applyTheme</span><span style=\"color:#E1E4E8\">() {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">  if</span><span style=\"color:#E1E4E8\"> (isDark.value) {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    document.documentElement.classList.</span><span style=\"color:#B392F0\">add</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'dark'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  } </span><span style=\"color:#F97583\">else</span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    document.documentElement.classList.</span><span style=\"color:#B392F0\">remove</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'dark'</span><span style=\"color:#E1E4E8\">)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  }</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">}</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;/</span><span style=\"color:#85E89D\">script</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span></code></pre>\n<h2>集成第三方服务</h2>\n<h3>添加评论系统</h3>\n<p>使用 Giscus：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">script</span><span style=\"color:#B392F0\"> src</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"https://giscus.app/client.js\"</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">        data-repo</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"your-username/your-repo\"</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">        data-repo-id</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"your-repo-id\"</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">        data-category</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"Announcements\"</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">        data-category-id</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"your-category-id\"</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">        data-mapping</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"pathname\"</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">        data-reactions-enabled</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"1\"</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">        data-emit-metadata</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"0\"</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">        data-input-position</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"bottom\"</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">        data-theme</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"light\"</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">        data-lang</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"zh-CN\"</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">        crossorigin</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"anonymous\"</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">        async</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;/</span><span style=\"color:#85E89D\">script</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span></code></pre>\n<h3>添加搜索功能</h3>\n<p>集成 Algolia DocSearch：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">link</span><span style=\"color:#B392F0\"> rel</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"stylesheet\"</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"https://cdn.jsdelivr.net/npm/@docsearch/css@3\"</span><span style=\"color:#E1E4E8\"> /></span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">script</span><span style=\"color:#B392F0\"> src</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"https://cdn.jsdelivr.net/npm/@docsearch/js@3\"</span><span style=\"color:#E1E4E8\">>&#x3C;/</span><span style=\"color:#85E89D\">script</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">script</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">  docsearch</span><span style=\"color:#E1E4E8\">({</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    appId: </span><span style=\"color:#9ECBFF\">'YOUR_APP_ID'</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    apiKey: </span><span style=\"color:#9ECBFF\">'YOUR_API_KEY'</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    indexName: </span><span style=\"color:#9ECBFF\">'YOUR_INDEX_NAME'</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    container: </span><span style=\"color:#9ECBFF\">'#docsearch'</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  })</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;/</span><span style=\"color:#85E89D\">script</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span></code></pre>\n<h3>添加分析统计</h3>\n<p>Google Analytics 4：</p>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">script</span><span style=\"color:#B392F0\"> async</span><span style=\"color:#B392F0\"> src</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"https://www.googletagmanager.com/gtag/js?id=G-XXXXXXXXXX\"</span><span style=\"color:#E1E4E8\">>&#x3C;/</span><span style=\"color:#85E89D\">script</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">script</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  window.dataLayer </span><span style=\"color:#F97583\">=</span><span style=\"color:#E1E4E8\"> window.dataLayer </span><span style=\"color:#F97583\">||</span><span style=\"color:#E1E4E8\"> [];</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">  function</span><span style=\"color:#B392F0\"> gtag</span><span style=\"color:#E1E4E8\">(){dataLayer.</span><span style=\"color:#B392F0\">push</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#79B8FF\">arguments</span><span style=\"color:#E1E4E8\">);}</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">  gtag</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'js'</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#F97583\">new</span><span style=\"color:#B392F0\"> Date</span><span style=\"color:#E1E4E8\">());</span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">  gtag</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'config'</span><span style=\"color:#E1E4E8\">, </span><span style=\"color:#9ECBFF\">'G-XXXXXXXXXX'</span><span style=\"color:#E1E4E8\">);</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;/</span><span style=\"color:#85E89D\">script</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span></code></pre>\n<h2>性能优化</h2>\n<h3>图片懒加载</h3>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">img</span><span style=\"color:#B392F0\"> src</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"placeholder.jpg\"</span><span style=\"color:#E1E4E8\"> </span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">     data-src</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"actual-image.jpg\"</span><span style=\"color:#E1E4E8\"> </span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">     loading</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"lazy\"</span><span style=\"color:#E1E4E8\"> </span></span>\n<span class=\"line\"><span style=\"color:#B392F0\">     alt</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"描述\"</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span></code></pre>\n<h3>预加载关键资源</h3>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">link</span><span style=\"color:#B392F0\"> rel</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"preload\"</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/fonts/inter.woff2\"</span><span style=\"color:#B392F0\"> as</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"font\"</span><span style=\"color:#B392F0\"> type</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"font/woff2\"</span><span style=\"color:#B392F0\"> crossorigin</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">&#x3C;</span><span style=\"color:#85E89D\">link</span><span style=\"color:#B392F0\"> rel</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"preload\"</span><span style=\"color:#B392F0\"> href</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"/critical.css\"</span><span style=\"color:#B392F0\"> as</span><span style=\"color:#E1E4E8\">=</span><span style=\"color:#9ECBFF\">\"style\"</span><span style=\"color:#E1E4E8\">></span></span>\n<span class=\"line\"></span></code></pre>\n<h3>Service Worker 缓存</h3>\n<pre class=\"shiki github-dark\" style=\"background-color:#24292e;color:#e1e4e8\" tabindex=\"0\"><code><span class=\"line\"><span style=\"color:#6A737D\">// service-worker.js</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">self.</span><span style=\"color:#B392F0\">addEventListener</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'install'</span><span style=\"color:#E1E4E8\">, (</span><span style=\"color:#FFAB70\">event</span><span style=\"color:#E1E4E8\">) </span><span style=\"color:#F97583\">=></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  event.</span><span style=\"color:#B392F0\">waitUntil</span><span style=\"color:#E1E4E8\">(</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    caches.</span><span style=\"color:#B392F0\">open</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'docs-v1'</span><span style=\"color:#E1E4E8\">).</span><span style=\"color:#B392F0\">then</span><span style=\"color:#E1E4E8\">((</span><span style=\"color:#FFAB70\">cache</span><span style=\"color:#E1E4E8\">) </span><span style=\"color:#F97583\">=></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">      return</span><span style=\"color:#E1E4E8\"> cache.</span><span style=\"color:#B392F0\">addAll</span><span style=\"color:#E1E4E8\">([</span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">        '/'</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">        '/index.html'</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">        '/assets/main.css'</span><span style=\"color:#E1E4E8\">,</span></span>\n<span class=\"line\"><span style=\"color:#9ECBFF\">        '/assets/main.js'</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">      ])</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    })</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  )</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">})</span></span>\n<span class=\"line\"></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">self.</span><span style=\"color:#B392F0\">addEventListener</span><span style=\"color:#E1E4E8\">(</span><span style=\"color:#9ECBFF\">'fetch'</span><span style=\"color:#E1E4E8\">, (</span><span style=\"color:#FFAB70\">event</span><span style=\"color:#E1E4E8\">) </span><span style=\"color:#F97583\">=></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  event.</span><span style=\"color:#B392F0\">respondWith</span><span style=\"color:#E1E4E8\">(</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    caches.</span><span style=\"color:#B392F0\">match</span><span style=\"color:#E1E4E8\">(event.request).</span><span style=\"color:#B392F0\">then</span><span style=\"color:#E1E4E8\">((</span><span style=\"color:#FFAB70\">response</span><span style=\"color:#E1E4E8\">) </span><span style=\"color:#F97583\">=></span><span style=\"color:#E1E4E8\"> {</span></span>\n<span class=\"line\"><span style=\"color:#F97583\">      return</span><span style=\"color:#E1E4E8\"> response </span><span style=\"color:#F97583\">||</span><span style=\"color:#B392F0\"> fetch</span><span style=\"color:#E1E4E8\">(event.request)</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">    })</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">  )</span></span>\n<span class=\"line\"><span style=\"color:#E1E4E8\">})</span></span>\n<span class=\"line\"></span></code></pre>\n<h2>总结</h2>\n<p>通过这些自定义选项，你可以：</p>\n<ul>\n<li>✅ 创建独特的视觉风格</li>\n<li>✅ 添加自定义功能组件</li>\n<li>✅ 增强 Markdown 渲染</li>\n<li>✅ 集成第三方服务</li>\n<li>✅ 优化性能和用户体验</li>\n</ul>\n<p>继续探索更多可能性！</p>\n","headings":[]},"lastModified":1768789337931}]}]}"))));</script>
|
|
10
|
+
<script type="module" crossorigin src="/assets/main-q6laQtCD.js"></script>
|
|
11
|
+
<link rel="stylesheet" crossorigin href="/assets/main-BZUsYUCF.css">
|
|
12
|
+
</head>
|
|
13
|
+
<body>
|
|
14
|
+
<div id="app">
|
|
15
|
+
<div class="loading">
|
|
16
|
+
<div style="text-align: center;">
|
|
17
|
+
<div style="font-size: 1.5rem; margin-bottom: 0.5rem;">📚</div>
|
|
18
|
+
<div>Loading Documentation...</div>
|
|
19
|
+
</div>
|
|
20
|
+
</div>
|
|
21
|
+
</div>
|
|
22
|
+
</body>
|
|
23
|
+
</html>
|