跳转到内容

重写参考

你可以通过在 Starlight 的 components 配置选项中提供替代组件的路径来替换掉 (即重写) Starlight 的内置组件。 本页面列出了所有可被重写的组件和它们默认实现的 GitHub 链接。

重写组件指南中了解更多。

组件参数

所有组件都可以使用标准的 Astro.props 对象,该对象包含有关当前页面的信息。

从 Starlight 导入 Props 类型来为你的自定义组件定义类型:

src/components/Custom.astro
---
import type { Props } from '@astrojs/starlight/props';
const { hasSidebar } = Astro.props;
// ^ type: boolean
---

这样当使用 Astro.props 时就会有自动补全和类型提示。

参数

Starlight 会将以下参数传递给你的自定义组件。

dir

类型: 'ltr' | 'rtl'

当前页面的文本方向。

lang

类型: string

当前页面的 BCP-47 语言标签,例如 enzh-CNpt-BR

locale

类型: string | undefined

当前语言的根路径。对于默认语言来说是 undefined

siteTitle

类型: string

根据页面语言设置的网站标题。

siteTitleHref

类型: string

网站标题的 href 属性值,链接回首页,例如 /。 对于多语言站点,将包含当前的语言环境,例如 /en//zh-cn/

slug

类型: string

从内容文件名生成的页面 slug。

此属性已废弃,将在未来的 Starlight 版本中移除。 通过使用 Starlight 的 docsLoader 迁移到新的内容层(Content Layer) API,并使用 id 属性替代。

id

类型: string

当前页面的 slug 或者如果你正在使用 legacy.collections,那么就是基于内容文件名的页面的唯一 ID。

isFallback

类型: true | undefined

如果此页面在当前语言中未翻译,回退到使用默认语言的内容,则为 true。 仅在多语言站点中使用。

entryMeta

类型: { dir: 'ltr' | 'rtl'; lang: string }

页面内容的语言环境元数据 (locale metadata)。当页面使用回退内容时可以与顶级语言环境设置值不同。

entry

当前页面所对应的 Astro 内容集合条目。 在 entry.data 中包含当前页面的 frontmatter 内容。

entry: {
data: {
title: string;
description: string | undefined;
// 等
}
}

Astro 的集合条目类型参考中了解更多关于此对象的信息。

类型: SidebarEntry[]

当前页面的侧边栏条目。

hasSidebar

类型: boolean

当前页面是否应该显示侧边栏。

pagination

类型: { prev?: Link; next?: Link }

如果启用了,当前页面在侧边栏中的上一页和下一页的链接。

toc

类型: { minHeadingLevel: number; maxHeadingLevel: number; items: TocItem[] } | undefined

如果启用了,当前页面的目录 (table of contents)。

headings

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

从当前页面提取的所有 Markdown 标题的数组。 如果你想要构建一个遵循 Starlight 配置选项的目录组件,请使用 toc

lastUpdated

类型: Date | undefined

如果启用了,表示此页面最后更新时间的 JavaScript Date 对象。

editUrl

类型: URL | undefined

如果启用了,表示可以编辑此页面的地址的 JavaScript URL 对象。


组件

头部

这些组件在每个页面的 <head> 元素内渲染。 它们应只包含允许在 <head> 中使用的元素

默认组件: Head.astro

在每个页面的 <head> 元素内渲染的组件。 包含 <title><meta charset="utf-8"> 等重要标签。

重写此组件应作为最后手段。 如果可能,请优先使用 Starlight 配置中的 head 选项。

ThemeProvider

默认组件: ThemeProvider.astro

<head> 内渲染的用于提供暗色/亮色主题支持的组件。 默认实现包括一个内联脚本和一个 <template>,该脚本在 <ThemeSelect /> 中使用该模板。


无障碍

默认组件: SkipLink.astro

<body> 内渲染的第一个元素,它链接到主页面内容以实现无障碍访问。 默认实现默认为隐藏状态,只有在用户使用键盘通过 tab 键聚焦到它时才会显示。


布局

这些组件负责在不同的断点 (breakpoints) 上布局 Starlight 的组件、管理视图。 重写这些组件会有很大的复杂性。 如果可能,请优先重写较低级别的组件。

PageFrame

默认组件: PageFrame.astro
命名插槽: header, sidebar

包在绝大部分页面内容外的布局组件。 默认实现提供了头部—侧边栏—主内容的布局,并包含 headersidebar 命名插槽以及主内容的默认插槽。 它还渲染了 <MobileMenuToggle /> 以支持在小 (移动) 视口 (viewports) 上切换侧边栏导航。

MobileMenuToggle

默认组件: MobileMenuToggle.astro

<PageFrame> 内渲染的负责在小 (移动) 视口上切换侧边栏导航的组件。

TwoColumnContent

默认组件: TwoColumnContent.astro
命名插槽: right-sidebar

包在主内容列和右侧栏 (目录) 外的布局组件。 默认实现实现了在单列、小视口布局和两列、较大视口布局之间的切换。


导航

这些组件渲染 Starlight 的顶部导航栏。

默认组件: Header.astro

在每个页面顶部显示的导航栏组件。 默认实现显示了 <SiteTitle /><Search /><SocialIcons /><ThemeSelect /><LanguageSelect />

SiteTitle

默认组件: SiteTitle.astro

在导航栏开头渲染的组件,用于渲染站点标题。 默认实现包含在 Starlight 配置中定义的 logo 的渲染逻辑。

默认组件: Search.astro

用于渲染 Starlight 搜索 UI 的组件。 默认实现包含在导航栏中的按钮和在点击时显示搜索模态框以及加载 Pagefind UI 的代码。

pagefind 被禁用时,默认的搜索组件不会被渲染。 然而,如果你重写了 Search,你的自定义组件将总是被渲染,即使 pagefind 配置选项是 false。 这允许你在禁用 Pagefind 时为其他搜索提供商添加 UI。

SocialIcons

默认组件: SocialIcons.astro

在导航栏中渲染的组件,用于渲染社交图标链接。 默认实现使用 Starlight 配置中的 social 选项来渲染图标和链接。

ThemeSelect

默认组件: ThemeSelect.astro

在导航栏中渲染的组件,用于允许用户选择深浅主题偏好。

LanguageSelect

默认组件: LanguageSelect.astro

在导航栏中渲染的组件,用于允许用户切换到不同的语言。


全局侧边栏

Starlight 的全局侧边栏包含了主站点导航。 在较窄的视口上,它会隐藏在下拉菜单中。

默认组件: Sidebar.astro

在页面内容之前渲染的包含全局导航的组件。 默认实现在足够宽的视口上显示为侧边栏,在小 (移动) 视口上显示为下拉菜单。 它还渲染了 <MobileMenuFooter /> 以在移动菜单中显示额外的项目。

MobileMenuFooter

默认组件: MobileMenuFooter.astro

在移动下拉菜单最底部中渲染的组件。 默认实现渲染了 <ThemeSelect /><LanguageSelect />


页面侧边栏

Starlight 的页面侧边栏负责显示当前页面的子标题的目录。 在较窄的视口上,它会缩为一个固定的下拉菜单。

PageSidebar

默认组件: PageSidebar.astro

在页面内容之前渲染的包含目录的组件。 默认实现渲染了 <TableOfContents /><MobileTableOfContents />

TableOfContents

默认组件: TableOfContents.astro

在较宽的视口上渲染当前页面的目录的组件。

MobileTableOfContents

默认组件: MobileTableOfContents.astro

在小 (移动) 视口上渲染当前页面的目录的组件。


内容

这些组件在页面主内容列中渲染。

默认组件: Banner.astro

横幅 (Banner) 组件在每个页面的顶部渲染。 默认实现使用页面的 banner frontmatter 值来决定是否渲染。

ContentPanel

默认组件: ContentPanel.astro

包在页面主内容列中的段落外的布局组件。

PageTitle

默认组件: PageTitle.astro

包含当前页面的 <h1> 元素的组件。

自定义实现应确保在 <h1> 元素上设置 id="_top",就像默认实现中一样。

DraftContentNotice

默认组件: DraftContentNotice.astro

在开发过程中,当当前页面被标记为草稿时,向用户显示的通知。

FallbackContentNotice

默认组件: FallbackContentNotice.astro

在本页面当前语言没有翻译时显示给用户的通知。 仅在多语言站点中使用。

Hero

默认组件: Hero.astro

当设置了 frontmatter 中的 hero 时在页面顶部渲染的组件。 默认实现显示了一个大标题、标语、动作链接 (call-to-action links) 和可选的图片。

MarkdownContent

默认组件: MarkdownContent.astro

在页面主内容列中渲染 Markdown 内容的组件。 默认实现为 Markdown 内容提供了基本的样式。

Markdown 内容样式也暴露在 @astrojs/starlight/style/markdown.css 中,并且作用域限制在 .sl-markdown-content CSS 类中。


页脚

这些组件在页面主内容列的底部渲染。

默认组件: Footer.astro

页脚 (Footer) 组件在每个页面的底部渲染。 默认实现显示了 <LastUpdated /><Pagination /><EditLink />

LastUpdated

默认组件: LastUpdated.astro

在页脚中渲染的组件,用于显示最后更新日期。

默认组件: EditLink.astro

在页脚中渲染的组件,用于显示指向页面编辑地址的链接。

Pagination

默认组件: Pagination.astro

在页脚中渲染的组件,用于显示上一页和下一页的导航箭头。