title | description | sidebar | ||
---|---|---|---|---|
页面 |
了解如何使用 Starlight 创建和管理文档站点页面。 |
|
Starlight 根据你的内容生成站点的 HTML 页面,并通过 Markdown frontmatter 提供灵活的选项。 此外,Starlight 项目可以完全使用 Astro 强大的页面生成工具。 本指南介绍了 Starlight 中的页面生成工作原理。
Starlight 支持使用 Markdown 和 MDX 编写内容,无需任何配置。 你可以通过安装实验性的 Astro Markdoc 集成 来添加对 Markdoc 的支持。
通过在 src/content/docs/
中创建 .md
或 .mdx
文件来添加新页面。
使用子文件夹来组织文件并创建多个路径段。
举个例子,以下文件结构将在 example.com/hello-world
和 example.com/reference/faq
生成页面:
import { FileTree } from '@astrojs/starlight/components';
- src/
- content/
- docs/
- hello-world.md
- reference/
- faq.md
- docs/
- content/
所有的 Starlight 页面都共享一个可定制的 通用 frontmatter 属性集,用于控制页面的外观:
---
title: Hello, World!
description: 这是我的 Starlight 网站中的一个页面
---
如果你忘记了一些重要的东西,Starlight 会提醒你。
对于高级用例,你可以通过创建 src/pages/
目录来添加自定义页面。
src/pages/
目录使用 Astro 的基于文件的路由, 并支持 .astro
文件等其他页面格式。
这对于需要完全自定义布局或从其他数据源生成页面的情况非常有用。
举个例子,以下文件结构将在 example.com/custom
和 example.com/archived
生成页面:
- src/
- content/
- docs/
- hello-world.md
- docs/
- pages/
- custom.astro
- archived.html
- content/
在 Astro 文档中的“页面”指南 中了解更多。
要在自定义页面中使用 Starlight 布局,请使用 <StarlightPage />
组件包装页面内容。
如果你正在动态生成内容但仍想使用 Starlight 的设计,这会很有帮助。
---
// src/pages/custom-page/example.astro
import StarlightPage from '@astrojs/starlight/components/StarlightPage.astro';
import CustomComponent from './CustomComponent.astro';
---
<StarlightPage frontmatter={{ title: '我的自定义页面' }}>
<p>这是一个有自定义组件的自定义页面:</p>
<CustomComponent />
</StarlightPage>
<StarlightPage />
组件接受以下 props。
类型: StarlightPageFrontmatter
为此页面设置 frontmatter 属性,类似于 Markdown 页面中的 frontmatter。
title
属性是必填的,其他所有属性都是可选的。
以下是与 Markdown frontmatter 不同的属性:
slug
属性不受支持,并且会根据自定义页面的 URL 自动设置。editUrl
选项需要一个 URL 来显示编辑链接。- 用于自定义页面如何在 自动生成的链接组 中显示的
sidebar
frontmatter 属性不可用。使用<StarlightPage />
组件的页面不是集合的一部分,不能添加到自动生成的侧边栏组中。 draft
选项仅会显示页面为草稿的 通知,但不会自动将其从生产版本中排除。
类型: SidebarEntry[]
默认值: 根据 全局 sidebar
配置 生成的侧边栏
为此页面提供自定义站点导航侧边栏。 如果未设置,此页面将使用默认的全局侧边栏。
例如,以下页面使用指向主页的链接和一组指向不同星座的链接覆盖了默认的侧边栏。
侧边栏中的当前页面使用 isCurrent
属性设置,一个可选的 badge
已经添加到了一个链接项中。
<StarlightPage
frontmatter={{ title: '猎户座' }}
sidebar={[
{ label: '首页', href: '/' },
{
label: '星座',
items: [
{ label: '仙女座', href: '/andromeda/' },
{ label: '猎户座', href: '/orion/', isCurrent: true },
{ label: '射手座', href: '/sagittarius/', badge: 'Stub' },
],
},
]}
>
示例内容。
</StarlightPage>
类型: boolean
默认值: 如果 frontmatter.template
是 'splash'
,为false
,否则为 true
控制是否在此页面上显示侧边栏。
类型: { depth: number; slug: string; text: string }[]
默认值: []
提供此页面上所有标题的数组。 如果提供了,Starlight 将从这些标题生成页面目录。
类型: 'ltr' | 'rtl'
默认值: 当前语言环境的书写方向
设置此页面内容的书写方向。
类型: string
默认值: 当前语言环境的语言
为此页面的内容设置 BCP-47 语言标签,例如 en
、zh-CN
或 pt-BR
。
类型: boolean
默认值: false
表示此页面是否使用了回退内容,因为当前语言没有翻译。