使用组件
组件能让你更轻松、更连贯地复用部分 UI 或者样式。 示例可能包括链接卡片或嵌入 YouTube。 Starlight 支持使用 MDX 和 Markdoc 文件中的组件,并提供了一些常用组件供你使用。
在 MDX 中使用组件
你可以通过将组件导入 MDX 文件然后将其渲染为 JSX 标签来使用该组件。
这些组件看起来像 HTML 标签,但是以 import
语句中的大写字母开头,并与之名称相匹配:
由于 Starlight 由 Astro 提供支持,因此你可以在 MDX 文件中添加由 受支持的 UI 框架(React、Preact、Svelte、Vue、Solid 和 Alpine) 构建的组件。 在 Astro 文档中了解有关 在 MDX 中使用组件 的更多信息。
在 Markdoc 中使用组件
跟随我们的 Markdoc 设置指南 来添加支持以在 Markdoc 中创作内容。
使用 Starlight 的 Markdoc 预设,你可以将 Starlight 的内置组件与 Markdoc 的 {% %}
标签语法结合使用。
与 MDX 不同的是,Markdoc 中的组件不需要导入。
以下示例为,在 Markdoc 文件中渲染 Starlight 的 卡片组件:
有关如何使用 Markdoc 文件中的组件的更多信息,请参阅 Astro Markdoc 集成文档。
内置组件
Starlight 为常见文档用例提供内置组件。
这些组件可从 MDX 文件中的 @astrojs/starlight/components
包以及 Markdoc 文件中的 Starlight Markdoc 预设 中获取。
请参阅侧边栏以获取可用组件的列表以及使用方式。
和 Starlight 样式的兼容性
Starlight 将默认样式应用于 Markdown 内容,例如,在元素之间添加边距。
如果这些样式与你的组件外观存在冲突,请在组件上设置 not-content
类来禁用它们。
组件 props
使用 astro/types
中的 ComponentProps
类型来引用组件接受的 Props
,即使它们不是由组件本身导出的。
这在包装或扩展现有组件时非常有用。
以下示例为,使用 ComponentProps
获取 Starlight 内置 Badge
组件接受的 props 类型: