Skip to content

侧边栏选项

本页介绍 VitePress 侧边栏的所有选项。

@ 快速搜索

解决路径问题分组
documentRootPathcollapsed
scanStartPathcollapseDepth
resolvePathrootGroupText
basePathrootGroupLink
rootGroupCollapsed
获取菜单标题获取菜单链接
useTitleFromFileHeadinguseFolderLinkFromSameNameSubFile
useTitleFromFrontmatterfolderLinkNotIncludesFileName
useFolderTitleFromIndexFileuseFolderLinkFromIndexFile
frontmatterTitleFieldName
包括/排除菜单标题样式
excludePatternhyphenToSpace
excludeFilesByFrontmatterFieldNameunderscoreToSpace
includeDotFilescapitalizeFirst
includeEmptyFoldercapitalizeEachWords
includeRootIndexFilekeepMarkdownSyntaxFromTitle
includeFolderIndexFileremovePrefixAfterOrdering
prefixSeparator
分类杂项
manualSortFileNameByPrioritydebugPrint
sortFolderTo
sortMenusByName
sortMenusByFileDatePrefix
sortMenusByFrontmatterOrder
frontmatterOrderDefaultValue
sortMenusByFrontmatterDate
sortMenusOrderByDescending
sortMenusOrderNumericallyFromTitle
sortMenusOrderNumericallyFromLink

documentRootPath

  • Type: string
  • Default: '/'

文档文件所在的顶级路径。默认值为 /

这是 .vitepress目录所在的路径,如果项目根目录中文档所在的文件夹是 /docs,则该选项的值应设为 docs/docs

text
/
├─ package.json
├─ src/
├─ docs/        <--------------- `documentRootPath` ('/docs')
│  ├─ .vitepress/        <------ VitePress 配置目录
│  ├─ another-directory/
│  ├─ hello.md
│  └─ index.md
└─ ...

scanStartPath

  • Type: string|null
  • Default: null

此选项用于配置多个侧边栏。您可以在 多个侧边栏 页面上了解更多信息。

用于扫描文档列表的根目录路径。在documentRootPath中设置的路径中的文件,在scanStartPath中设置的路径之外,不会被扫描。如果您指定了scanStartPath,建议您也设置documentRootPath,因为documentRootPath中设置的父路径应该出现在link中。

例如,如果根路径是/docs,要扫描的文件是/docs/sub-dir/scan-me,则设置如下:

  • documentRootPath: /docs,
  • scanStartPath: sub-dir/scan-me (请勿包含 documentRootPath 的路径。)

resolvePath

  • Type: string|null
  • Default: null

此选项用于配置多个侧边栏。您可以在 多个侧边栏 页面上了解更多信息。

输入路径,为每个路径显示不同的侧边栏。路径前必须包含/。没有此值的选项将设置为根路径(/)。

例如: /, /path/sub-path, /guide/...

basePath

  • Type: string|null
  • Default: null

此选项用于配置多个侧边栏。您可以在 多个侧边栏 页面上了解更多信息。

如果路径因VitePress的重写选项而改变,则可以使用此选项。它替换VitePress中的基本路径。如果此值不存在,则将使用来自resolvePath的值。

useTitleFromFileHeading

  • Type: boolean
  • Default: false

如果值为 true,则显示带有 .md 文件中 h1 标题内容的标题。如果文件中不存在 h1 标题,则显示 Unknown

默认菜单项按文件夹树顺序排序,因此如果您想按更改后的菜单名称重新排序,请将sortMenusByName选项设置为true

useTitleFromFrontmatter

  • Type: boolean
  • Default: false

如果值为true,则根据文件Frontmattertitle的值显示标题。如果无法解析该值,则如果useTitleFromFileHeading选项为true,则从h1标签中获取该值,如果失败,则从文件名中获取该值。

Frontmatter应位于文档顶部,并应如下所示(在 title: 值和标题之间需要留出空格)。

markdown
---
title: Hello World
---

frontmatterTitleFieldName

  • Type: string
  • Default: title

根据文件中指定的Frontmatter中的键名显示菜单标题。如果指定的值在Frontmatter中不存在,将使用默认的title作为后备。

markdown
---
name: This is frontmatter title value.
---

欲了解更多信息,请参阅以下文章: https://vitepress.dev/guide/frontmatter

默认菜单项是按文件夹树顺序排序的,因此如果想按更改后的菜单名称重新排序,请将 sortMenusByName 选项设置为 true

useFolderTitleFromIndexFile

  • Type: boolean
  • Default: false

如果该值为 true,则使用当前文件夹的 index.md 文件中的信息来获取菜单名称。如果不存在 index.md 文件,则使用文件夹名称。由于我们通常从 index.md 文件中获取 index 名称,因此建议同时使用 useTitleFromFileHeadinguseTitleFromFrontmatter 选项,从该文件的 Markdown 标题或 Frontmatter 中获取标题。

侧边栏菜单会隐藏 index.md 文件,但如果 includeFolderIndexFile 选项为 true,索引文件就会显示在菜单中。

useFolderLinkFromIndexFile

  • Type: boolean
  • Default: false

如果此值为 true,将指定一个指向文件夹的链接,以便您可以导航到当前文件夹中的 index.md 文件。如果 index.md 文件不存在,则不会创建链接。

侧边栏菜单会隐藏 index.md 文件,但如果 includeFolderIndexFile 选项为 true,则可在菜单中显示索引文件。

manualSortFileNameByPriority

  • Type: Array<string>
  • Default: []

按文件名(包括扩展名)数组的顺序排序。如果数组中没有与文件名匹配的值,排序优先级将被退回。这适用于文件和目录,同样的排列规则也适用于子目录。

sortFolderTo

  • Type: undefined | 'top' | 'bottom'
  • Default: undefined

完成所有排序后,文件夹和文件将被分批放置。如果值为 top,则所有文件夹都放在文件上方;如果为 bottom,则放在文件下方。子文件夹中的项目也会一起排序。

sortMenusByName

  • Type: boolean
  • Default: false

按名称对菜单项中的项目进行排序。通常情况下,文件夹扫描是按名称升序排序的,因此,如果不应用此选项,则应用默认排序,但如果使用useTitleFromFileHeadinguseTitleFromFrontmatter选项,则可能需要按名称重新排序,因为菜单名称已更改。此选项强制按名称排序,即使菜单名称已更改也是如此。

sortMenusByFileDatePrefix

  • Type: boolean
  • Default: false

如果值为 true,则按菜单项名称中的日期前缀排序。日期格式必须是 YYYY-MM-DD 格式(例如 2024-01-01-menu-name, 2024-01-02.menu-name...)

要删除菜单文本中残留的日期前缀,可以使用 prefixSeparatorremovePrefixAfterOrdering 选项。

默认菜单项是按文件夹树顺序排序的,因此如果想按更改后的菜单名称重新排序,请将 sortMenusByName 选项设置为 true

sortMenusByFrontmatterOrder

  • Type: boolean
  • Default: false

按 frontmatter 的 order 属性对菜单项排序。对于每个文件夹,按 order 属性的值(数字)升序排序,如果 sortMenusOrderByDescending 选项为 true,则按降序排序。如果 order 属性的值不是数字或不存在,则 order 会被判定为 0

sortMenusByFrontmatterDate

  • Type: boolean
  • Default: false

根据前端的date属性对菜单项进行排序。它还会按日期升序(如果sortMenusOrderByDescendingtrue,则按日期降序)对date属性值进行排序。日期格式必须符合YYYY-MM-DD或JavaScript Date数据类型。

sortMenusOrderByDescending

  • Type: boolean
  • Default: false

如果此值为 true,则按降序排列菜单项中的项目。只有当 sortMenusByNamesortMenusByFrontmatterOrdertrue时,才会启用此选项。

sortMenusOrderNumericallyFromTitle

  • Type: boolean
  • Default: false

如果该值为true,则如果菜单名称以数字开头,则按数字而不是名称排序。例如,如果您有名为1-a10-a2-a的文件,则常规排序将按名称排序,即['1-a', '10-a', '2-a']。这会导致菜单以非预期的顺序显示,因为10-a优先于2-a

使用此选项,它们按以下顺序排序:['1-a', '2-a', '10-a']

如果您希望按降序排序,则应与sortMenusOrderByDescending选项一起使用。

  • Type: boolean
  • Default: false

如果此值为true,则如果菜单名称以数字开头,则按数字而不是名称排序。此选项与sortMenusOrderNumericallyFromTitle相同,但按链接而不是文件标题排序。因此,它不能与sortMenusOrderNumericallyFromTitle选项一起使用。

如果您希望按降序排序,则应与sortMenusOrderByDescending选项一起使用。

frontmatterOrderDefaultValue

  • Type: number
  • Default: 0

设置 frontmatter 的 order 属性未设置时的默认值。该选项仅在 sortMenusByFrontmatterOrdertrue 时启用。

collapsed

  • Type: boolean
  • Default: false

如果未指定collapsed选项(nullundefined),则不使用分组折叠/展开,所有菜单将一次性显示。如果为false,则创建菜单时所有分组都处于展开状态。如果为true,则创建菜单时所有分组都处于折叠状态。

(即使值为true,如果菜单位于折叠组中的文档中,也可能被展开。)

Collapsed Example

collapseDepth

  • Type: number
  • Default: 1

在指定的深度,菜单组会折叠。指定该选项后,组的折叠/展开将自动启用。顶层文件夹的深度为 1

hyphenToSpace

  • Type: boolean
  • Default: false

如果值为 true,文件名中的-符号将转换为空格并显示为标题。通过 Markdown 标题或 frontmatter 导入菜单名称时,该选项也会受到影响。

underscoreToSpace

  • Type: boolean
  • Default: false

如果值为 true,文件名中的_符号将转换为空格并显示为标题。通过 Markdown 标题或 frontmatter 导入菜单名称时,该选项也会受到影响。

capitalizeFirst

  • Type: boolean
  • Default: false

如果值为 true,菜单名称的第一个字母将强制为大写。当菜单名称通过 Markdown 标题或 frontmatter 导入时,该选项也会受到影响。

capitalizeEachWords

  • Type: boolean
  • Default: false

如果值为 true,将大写由特殊字符分隔的单词的所有首字母。当菜单名称通过 markdown 标头或 Frontmatter 导入时,该选项也会受到影响。

例如,abc def ghiabc-def ghi将分别变为Abc Def GhiAbc-Def Ghi

excludePattern

  • Type: Array<string>
  • Default: []

glob 根据文件模式字符串数组排除文件或文件夹。

例如,该值可能如下所示['abc/', 'def.md', 'ghi/file-**']这将分别排除所有路径中的abc目录和子目录、def.md文件以及ghi路径中以file-开头的文件,这些文件和文件夹将被排除在菜单之外。

excludeFilesByFrontmatterFieldName

  • Type: string|null
  • Default: null

指定前缀字段名称为true的文档将从菜单中排除。

如果未指定选项或选项值未定义,则忽略该选项。

例如,如果选项值为exclude,则菜单中不会显示内容包含exclude: true的文档。

markdown
---
title: This article is excluded.
exclude: true
---

# Article

Content

根据选项的值,您可以使用其他名称,如drafthide等,来代替exclude

includeDotFiles

  • Type: boolean
  • Default: false

通常情况下,如果文件和文件夹名称前有句点(.),它们会被视为隐藏文件,不会在列表中显示。但是,如果此选项为true,则强制在列表中显示所有隐藏文件和文件夹。

includeEmptyFolder

  • Type: boolean
  • Default: false

如果值为true,则还会显示不存在md文件的目录。

includeRootIndexFile

  • Type: boolean
  • Default: false

如果值为true,则还要在侧边栏菜单中包含顶级路径index.md文件。使用includeFolderIndexFile选项还可以包含子项目的索引文件。(如果文件不存在,则忽略它。)

includeFolderIndexFile

  • Type: boolean
  • Default: false

如果值为true,则还要在侧边栏菜单中包含文件夹路径index.md文件。使用includeRootIndexFile选项还可以包含根项目的索引文件。(如果文件不存在,则忽略它。)

removePrefixAfterOrdering

  • Type: boolean
  • Default: false

从所有操作完成后显示的菜单项的每个菜单标题中删除特定的前缀。如果您想按文件名中的数字排序,而不使用前缀的排序,并且不希望该数字在菜单中显示,这是理想的选择。

例如,如果默认使用前缀分隔符(.),则以下菜单将重命名为

  • 文件名:1.hello -> 菜单名:hello
  • 文件名:1.1.hello -> 菜单名:1.hello
  • 文件名:1-1.hello -> 菜单名:hello

根据分隔符仅删除一次字母,因此子项(如1.1.)应使用1-1.。或者,您可以在前缀分隔符值上设置正则表达式来绕过它。

可与prefixSeparator选项一起使用。更多信息请参阅该选项的描述。

(注A:前缀仅影响标题,链接将使用文件链接的原始形式)。

(备注B:如果您使用useTitleFromFileHeadinguseTitleFromFrontmatter选项,则忽略此选项)。

prefixSeparator

  • Type: string|RegExp
  • Default: '.'

此选项只能与 removePrefixAfterOrdering 选项结合使用以删除前缀。

从提取的菜单文本中删除指定数量字符(至少一个)的第一部分。例如,如果菜单名称为 1. Text,并且您将 prefixSeparator 值设置为 . ,则结果将仅为 Text

您还可以使用正则表达式。与正则表达式匹配的值将被删除。例如,要删除 2024-01-01-hello 中字符串之前的日期,请将 prefixSeparator 值指定为 /[0-9]{4}-[0-9]{2}-[0-9]{2}-/g。结果为 hello

rootGroupText

  • Type: string
  • Default: 'Table of Contents'

rootGroup 指定整个菜单组,而与目录结构无关。这将使用一个菜单步骤,因此您在使用时应格外小心。如果您不需要 rootGroup 选项,可以将其禁用。如果指定此值,则指定顶级菜单的名称。

  • Type: string
  • Default: null

有关 rootGroup 的更多信息,请参阅 rootGroupText 选项说明。指定此值可指定指向 rootGroup 的链接。如果值为空,则不添加链接。

rootGroupCollapsed

  • Type: boolean
  • Default: null

有关 rootGroup 的更多信息,请参阅 rootGroupText 选项说明。rootGroupCollapsed选项设置是否展开根组的子项。如果指定的默认值为 nullundefined,则不显示展开/折叠按钮。如果该值为 true,子项将以折叠方式显示;如果为 false,子项将以展开方式显示。

此选项仅适用于顶层项目。有关一般项目的折叠性,请参阅 collapsed 选项。

useFolderLinkFromSameNameSubFile

  • Type: boolean
  • Default: false

如果此值为true,则当存在与文件夹同名的子文件时,将在文件夹中创建一个链接,用于导航至该文件,而该文件不会显示在子项中。

例如,如果您有一个文件夹,如下所示:

docs/
├─ guide/
│  ├─ api/
│  │  └─ api.md
│  ├─ one.md
│  └─ two.md
└─ config/
   └─ index.md

api 文件夹中添加了一个链接,而 api 文件夹中的 api 页面不包含在菜单列表中。点击文件夹中的链接会显示 api/api.md中的文件。

folderLinkNotIncludesFileName

  • Type: boolean
  • Default: false

此选项仅在特殊情况下使用:当您有重写规则并且存在具有相同文件夹名称的子文件时,请将其与 useFolderLinkFromSameNameSubFile 选项并行使用。

如果此值为 true,则在建立文件夹链接时,忽略子项的存在,并仅将链接指定为文件夹路径。

例如,如果您有一个如下所示的文件夹:

docs/
├─ guide/
│  ├─ api/
│  │  └─ api.md
│  ├─ one.md
│  └─ two.md
└─ config/
   └─ index.md

使用 useFolderLinkFromSameNameSubFile 选项,单击 guide/api 文件夹菜单将带您进入 guide/api/api,但如果您使用 folderLinkNotIncludesFileName 选项,则链接将为 guide/api/

keepMarkdownSyntaxFromTitle

  • Type: boolean
  • Default: false

如果此值为 true,则保留标题文本中包含的 Markdown 语法,而不删除它。通常会保留任何高亮或内联代码。无论是否使用此选项,超链接文本都会被移除。

debugPrint

  • Type: boolean
  • Default: false

如果该值为true,则会将执行后创建的对象打印到控制台日志中。如果您配置了多个侧边栏,即使只包含其中一个选项,它也会输出所有侧边栏的结果。

Released under the MIT License