侧边栏选项
本页介绍 VitePress 侧边栏的所有选项。
@ 快速搜索
解决路径问题 | 分组 |
---|---|
documentRootPath | collapsed |
scanStartPath | collapseDepth |
resolvePath | rootGroupText |
basePath | rootGroupLink |
rootGroupCollapsed |
获取菜单标题 | 获取菜单链接 |
---|---|
useTitleFromFileHeading | useFolderLinkFromSameNameSubFile |
useTitleFromFrontmatter | folderLinkNotIncludesFileName |
useFolderTitleFromIndexFile | useFolderLinkFromIndexFile |
frontmatterTitleFieldName |
documentRootPath
- Type:
string
- Default:
'/'
文档文件所在的顶级路径。默认值为 /
。
这是 .vitepress
目录所在的路径,如果项目根目录中文档所在的文件夹是 /docs
,则该选项的值应设为 docs
或 /docs
。
/
├─ 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
,则根据文件Frontmatter
中title
的值显示标题。如果无法解析该值,则如果useTitleFromFileHeading
选项为true
,则从h1
标签中获取该值,如果失败,则从文件名中获取该值。
Frontmatter
应位于文档顶部,并应如下所示(在 title:
值和标题之间需要留出空格)。
---
title: Hello World
---
frontmatterTitleFieldName
- Type:
string
- Default:
title
根据文件中指定的Frontmatter中的键名显示菜单标题。如果指定的值在Frontmatter中不存在,将使用默认的title
作为后备。
---
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
名称,因此建议同时使用 useTitleFromFileHeading
或 useTitleFromFrontmatter
选项,从该文件的 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
按名称对菜单项中的项目进行排序。通常情况下,文件夹扫描是按名称升序排序的,因此,如果不应用此选项,则应用默认排序,但如果使用useTitleFromFileHeading
或useTitleFromFrontmatter
选项,则可能需要按名称重新排序,因为菜单名称已更改。此选项强制按名称排序,即使菜单名称已更改也是如此。
sortMenusByFileDatePrefix
- Type:
boolean
- Default:
false
如果值为 true
,则按菜单项名称中的日期前缀排序。日期格式必须是 YYYY-MM-DD
格式(例如 2024-01-01-menu-name
, 2024-01-02.menu-name
...)
要删除菜单文本中残留的日期前缀,可以使用 prefixSeparator
和 removePrefixAfterOrdering
选项。
默认菜单项是按文件夹树顺序排序的,因此如果想按更改后的菜单名称重新排序,请将 sortMenusByName
选项设置为 true
。
sortMenusByFrontmatterOrder
- Type:
boolean
- Default:
false
按 frontmatter 的 order
属性对菜单项排序。对于每个文件夹,按 order
属性的值(数字)升序排序,如果 sortMenusOrderByDescending
选项为 true
,则按降序排序。如果 order
属性的值不是数字或不存在,则 order
会被判定为 0
。
sortMenusByFrontmatterDate
- Type:
boolean
- Default:
false
根据前端的date
属性对菜单项进行排序。它还会按日期升序(如果sortMenusOrderByDescending
为true
,则按日期降序)对date
属性值进行排序。日期格式必须符合YYYY-MM-DD
或JavaScript Date数据类型。
sortMenusOrderByDescending
- Type:
boolean
- Default:
false
如果此值为 true
,则按降序排列菜单项中的项目。只有当 sortMenusByName
或 sortMenusByFrontmatterOrder
为 true
时,才会启用此选项。
sortMenusOrderNumericallyFromTitle
- Type:
boolean
- Default:
false
如果该值为true
,则如果菜单名称以数字开头,则按数字而不是名称排序。例如,如果您有名为1-a
、10-a
和2-a
的文件,则常规排序将按名称排序,即['1-a', '10-a', '2-a']
。这会导致菜单以非预期的顺序显示,因为10-a
优先于2-a
。
使用此选项,它们按以下顺序排序:['1-a', '2-a', '10-a']
如果您希望按降序排序,则应与sortMenusOrderByDescending
选项一起使用。
sortMenusOrderNumericallyFromLink
- Type:
boolean
- Default:
false
如果此值为true
,则如果菜单名称以数字开头,则按数字而不是名称排序。此选项与sortMenusOrderNumericallyFromTitle
相同,但按链接而不是文件标题排序。因此,它不能与sortMenusOrderNumericallyFromTitle
选项一起使用。
如果您希望按降序排序,则应与sortMenusOrderByDescending
选项一起使用。
frontmatterOrderDefaultValue
- Type:
number
- Default:
0
设置 frontmatter 的 order
属性未设置时的默认值。该选项仅在 sortMenusByFrontmatterOrder
为 true
时启用。
collapsed
- Type:
boolean
- Default:
false
如果未指定collapsed
选项(null
或 undefined
),则不使用分组折叠/展开,所有菜单将一次性显示。如果为false
,则创建菜单时所有分组都处于展开状态。如果为true
,则创建菜单时所有分组都处于折叠状态。
(即使值为true
,如果菜单位于折叠组中的文档中,也可能被展开。)
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 ghi
和abc-def ghi
将分别变为Abc Def Ghi
和Abc-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
的文档。
---
title: This article is excluded.
exclude: true
---
# Article
Content
根据选项的值,您可以使用其他名称,如draft
、hide
等,来代替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:如果您使用useTitleFromFileHeading
或useTitleFromFrontmatter
选项,则忽略此选项)。
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 选项,可以将其禁用。如果指定此值,则指定顶级菜单的名称。
rootGroupLink
- Type:
string
- Default:
null
有关 rootGroup 的更多信息,请参阅 rootGroupText
选项说明。指定此值可指定指向 rootGroup 的链接。如果值为空,则不添加链接。
rootGroupCollapsed
- Type:
boolean
- Default:
null
有关 rootGroup 的更多信息,请参阅 rootGroupText
选项说明。rootGroupCollapsed
选项设置是否展开根组的子项。如果指定的默认值为 null
或 undefined
,则不显示展开/折叠按钮。如果该值为 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
,则会将执行后创建的对象打印到控制台日志中。如果您配置了多个侧边栏,即使只包含其中一个选项,它也会输出所有侧边栏的结果。