跳转到内容

页面

Starlight 根据你的内容生成站点的 HTML 页面,并通过 Markdown frontmatter 提供灵活的选项。 此外,Starlight 项目可以完全使用 Astro 强大的页面生成工具。 本指南介绍了 Starlight 中的页面生成工作原理。

内容页面

文件格式

Starlight 支持使用 Markdown 和 MDX 编写内容,无需任何配置。 你可以通过安装实验性的 Astro Markdoc 集成 来添加对 Markdoc 的支持。

添加页面

通过在 src/content/docs/ 中创建 .md.mdx 文件来添加新页面。 使用子文件夹来组织文件并创建多个路径段。

举个例子,以下文件结构将在 example.com/hello-worldexample.com/reference/faq 生成页面:

  • 文件夹src/
    • 文件夹content/
      • 文件夹docs/
        • hello-world.md
        • 文件夹reference/
          • faq.md

类型安全的 frontmatter

所有的 Starlight 页面都共享一个可定制的 通用 frontmatter 属性集,用于控制页面的外观:

---
title: Hello, World!
description: 这是我的 Starlight 网站中的一个页面
---

如果你忘记了一些重要的东西,Starlight 会提醒你。

自定义页面

对于高级用例,你可以通过创建 src/pages/ 目录来添加自定义页面。 src/pages/ 目录使用 Astro 的基于文件的路由, 并支持 .astro 文件等其他页面格式。

这对于需要完全自定义布局或从其他数据源生成页面的情况非常有用。

举个例子,以下文件结构将在 example.com/customexample.com/archived 生成页面:

  • 文件夹src/
    • 文件夹content/
      • 文件夹docs/
        • hello-world.md
    • 文件夹pages/
      • custom.astro
      • archived.html

Astro 文档中的“页面”指南 中了解更多。

在自定义页面中使用 Starlight 的设计

要在自定义页面中使用 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>

Props

<StarlightPage /> 组件接受以下 props。

frontmatter (必填)

类型: 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>
hasSidebar

类型: boolean
默认值: 如果 frontmatter.template'splash',为false,否则为 true

控制是否在此页面上显示侧边栏。

headings

类型: { depth: number; slug: string; text: string }[]
默认值: []

提供此页面上所有标题的数组。 如果提供了,Starlight 将从这些标题生成页面目录。

dir

类型: 'ltr' | 'rtl'
默认值: 当前语言环境的书写方向

设置此页面内容的书写方向。

lang

类型: string
默认值: 当前语言环境的语言

为此页面的内容设置 BCP-47 语言标签,例如 enzh-CNpt-BR

isFallback

类型: boolean
默认值: false

表示此页面是否使用了回退内容,因为当前语言没有翻译。