软件开发的核心原则之一是 DRY(Don’t Repeat Yourself,避免重复),这同样适用于文档。如果你发现在多个位置重复相同的内容,可以为该内容创建一个自定义片段。片段包含的内容可以导入到其他文件中复用,你可以控制片段在页面上的具体展示位置。如果之后需要更新内容,只需编辑片段本身,而不必修改所有使用该片段的文件。
片段是被导入到其他文件中的任意 .mdx、.md 或 .jsx 文件。你可以将片段文件放在项目中的任意位置。
当你在另一个文件中导入片段时,该片段只会在你导入它的地方出现,并不会渲染为独立页面。/snippets/ 文件夹中的任何文件始终被视为片段,即使它没有被导入到其他文件中。
创建一个文件,写入你想要复用的内容。片段可以包含 Mintlify 支持的所有内容类型,也可以导入其他片段。
使用绝对路径或相对路径将代码片段导入到页面中。
绝对导入 :从项目根目录导入时,以 / 开头。
相对导入 :使用 ./ 或 ../ 从当前文件所在位置相对导入代码片段。
相对导入支持 IDE 导航。在编辑器中按住 CMD 并单击代码片段名称即可直接跳转到该代码片段的定义。
在代码片段文件中添加需要复用的内容。
Hello world! This is my content I want to reuse across pages.
使用绝对路径或相对路径,将该片段导入目标文件中。
Absolute import
Relative import
---
title : "An example page"
description : "This is an example page that imports a snippet."
---
import MySnippet from "/shared/my-snippet.mdx" ;
The snippet content displays beneath this sentence.
< MySnippet />
在页面中引用代码片段(snippet)中的变量。
从代码片段(snippet)文件中导出变量。
shared/custom-variables.mdx
export const myName = "Ronan" ;
export const myObject = { fruit: "strawberries" };
;
从目标文件中导入该代码片段并使用该变量。
---
title : "示例页面"
description : "这是一个导入带有变量的代码片段的示例页面。"
---
import { myName , myObject } from "/shared/custom-variables.mdx" ;
你好,我的名字是 { myName } ,我喜欢 { myObject . fruit } 。
在导入代码片段时,可使用变量向其传递数据。
在代码片段中添加变量,并在导入时通过属性传入值。在此示例中,变量是 {word}。
使用该变量将代码片段导入目标文件。传入的属性会替换代码片段定义中的变量。
---
title : "示例页面"
description : "这是一个导入带有变量的代码片段的示例页面。"
---
import MySnippet from "/shared/my-snippet.mdx" ;
< MySnippet word = "bananas" />
创建一个包含 JSX 组件的代码片段。有关更多信息,请参见 React 组件 。
components/my-jsx-snippet.jsx
export const MyJSXSnippet = () => {
return (
< div >
< h1 > 你好,世界! </ h1 >
</ div >
);
};
创建 JSX 代码片段时,请使用箭头函数语法(=>),而不要使用函数声明。在代码片段中不支持使用 function 关键字。
导入该代码片段。
---
title : "示例页面"
description : "这是一个导入包含 React 组件的代码片段的示例页面。"
---
import { MyJSXSnippet } from "/components/my-jsx-snippet.jsx" ;
< MyJSXSnippet />