扩展 MDX
¥Extending MDX
本文介绍如何扩展 MDX 内容,具体来说,如何使用插件转换内容。 请参阅 § 使用 MDX 了解如何传递组件、属性和布局。请参阅 § 入门 了解如何将 MDX 集成到你的项目中。
¥This article explains how to extend MDX content—specifically, how to transform content with plugins. See § Using MDX for how to pass components, props, and the layout. See § Getting started for how to integrate MDX into your project.
内容
¥Contents
组件和插件
¥Components & plugins
使用 @mdx-js/mdx
或其集成之一时,存在三个扩展点:
¥There are three extension points when using @mdx-js/mdx
or one of its integrations:
传递给编译器的选项(参见 ¶
@mdx-js/mdx
中的 API)¥Options passed to the compiler (see ¶ API in
@mdx-js/mdx
)钩子到编译的多个阶段的插件(请参阅 remark 插件、rehype 插件 和新的 recma 插件)
¥Plugins that hook into several stages of compilation (see remark plugins, rehype plugins, and the new recma plugins)
在运行时传递、定义或导入的组件(参见 § 使用 MDX)
¥Components passed, defined, or imported at runtime (see § Using MDX)
大多数时候,这些组件和插件不与 MDX 耦合。例如,如果你使用 React,那么你可以将 <ReactConfetti />
与 MDX 结合使用。或者,你可以使用插件 remark-gfm
打开 MDX 中的 GFM 功能。有时,我们需要特定的组件或特定的插件来使用 MDX。我们正在此页面上整理这些内容。
¥Most of the time, these components and plugins are not coupled to MDX. For example, if you’re using React, then you can use <ReactConfetti />
with MDX. Or, you can use the plugin remark-gfm
to turn on GFM features in MDX. Sometimes, we need specific components or specific plugins to work with MDX. We’re compiling those here on this page.
组件清单
¥List of components
PaulieScanlon/mdx-embed
- 用于嵌入第 3 方内容的 React 组件,与 MDX 提供程序集成¥
PaulieScanlon/mdx-embed
— React components for embedding 3rd party content, integrates w/ MDX providersystem-ui/theme-ui
- 用于构建一致应用的 React 组件,与 MDX 提供程序集成¥
system-ui/theme-ui
— React components for building consistent apps, integrates w/ MDX provider
注意:还有另一个专门与 MDX 配合使用的组件吗?请发送 PR 将其添加到此处!
¥Note: have another component that specifically works with MDX? Please send a PR to add it here!
插件列表
¥List of plugins
另请参见 remark 插件列表 和 rehype 插件列表。
¥See also the list of remark plugins and list of rehype plugins.
remcohaszing/recma-export-filepath
— 导出文件路径¥
remcohaszing/recma-export-filepath
— export the filepathipikuka/recma-mdx-change-props
— 将_createMdxContent
函数中的参数更改为_props
¥
ipikuka/recma-mdx-change-props
— changes the param as_props
in the_createMdxContent
functiondomdomegg/recma-mdx-displayname
— 添加displayName
到MDXContent
组件,以在生产中启用它们¥
domdomegg/recma-mdx-displayname
— add adisplayName
toMDXContent
components, to enable switching on them in productionipikuka/recma-mdx-escape-missing-components
— 为缺少的组件设置默认值() => null
,而不是抛出错误¥
ipikuka/recma-mdx-escape-missing-components
— set a default value of() => null
for missing components instead of throwing an errorremcohaszing/recma-mdx-is-mdx-component
— 在 MDX 组件上添加isMdxComponent
字段¥
remcohaszing/recma-mdx-is-mdx-component
— add anisMdxComponent
field on MDX componentsremcohaszing/recma-nextjs-static-props
— 生成getStaticProps
,在 Next.js 中公开顶层标识符¥
remcohaszing/recma-nextjs-static-props
— generategetStaticProps
exposing top level identifiers in Next.jsremcohaszing/rehype-mdx-code-props
— 将代码meta
字段解释为 JSX props¥
remcohaszing/rehype-mdx-code-props
— interpret the codemeta
field as JSX propsremcohaszing/rehype-mdx-import-media
— 将媒体源更改为 JavaScript 导入¥
remcohaszing/rehype-mdx-import-media
— change media sources to JavaScript importsremcohaszing/rehype-mdx-title
— 将页面标题公开为字符串¥
remcohaszing/rehype-mdx-title
— expose the page title as a stringpangelani/remark-mdx-chartjs
— 使用react-chartjs-2
将隔离代码块替换为图表。¥
pangelani/remark-mdx-chartjs
— replace fenced code blocks with charts usingreact-chartjs-2
.remcohaszing/remark-mdx-frontmatter
— 将 frontmatter (YAML) 元数据更改为导出¥
remcohaszing/remark-mdx-frontmatter
— change frontmatter (YAML) metadata to exportsgoodproblems/remark-mdx-math-enhanced
— 使用 JavaScript 增强数学能力¥
goodproblems/remark-mdx-math-enhanced
— enhance math with JavaScript inside it
注意:有另一个专门与 MDX 配合使用的统一插件吗?请发送 PR 将其添加到此处!
¥Note: have another unified plugin that specifically works with MDX? Please send a PR to add it here!
使用插件
¥Using plugins
插件名称中编码了传递插件的位置:remark 插件位于 remarkPlugins
中,rehype 插件位于 ProcessorOptions
的 rehypePlugins
中。这些字段需要插件和/或 [plugin, options]
的列表:
¥Where to pass plugins is encoded in their name: remark plugins go in remarkPlugins
and rehype plugins go in rehypePlugins
of ProcessorOptions
. Those fields expect lists of plugins and/or of [plugin, options]
:
import {compile} from '@mdx-js/mdx'
import rehypeKatex from 'rehype-katex' // Render math with KaTeX.
import remarkFrontmatter from 'remark-frontmatter' // YAML and such.
import remarkGfm from 'remark-gfm' // Tables, footnotes, strikethrough, task lists, literal URLs.
import remarkMath from 'remark-math' // Support math like `$so$`.
const file = '# hi'
// One plugin:
await compile(file, {remarkPlugins: [remarkGfm]})
// A plugin with options:
await compile(file, {remarkPlugins: [[remarkFrontmatter, 'toml']]})
// Two plugins:
await compile(file, {remarkPlugins: [remarkGfm, remarkFrontmatter]})
// Two plugins, first w/ options:
await compile(file, {remarkPlugins: [[remarkGfm, {singleTilde: false}], remarkFrontmatter]})
// remark and rehype plugins:
await compile(file, {rehypePlugins: [rehypeKatex], remarkPlugins: [remarkMath]})
// remark and rehype plugins, last w/ options:
await compile(file, {
// A plugin with options:
rehypePlugins: [[rehypeKatex, {strict: true, throwOnError: true}]],
remarkPlugins: [remarkMath]
})
(alias) function compile(vfileCompatible: any, compileOptions?: Readonly<CompileOptions> | null | undefined): Promise<VFile>
import compile
Compile MDX to JS.
- @param vfileCompatible MDX document to parse.
- @param compileOptions Compile configuration (optional).
- @return Promise to compiled file.
(alias) function rehypeKatex(options?: Readonly<Options> | null | undefined): (tree: Root, file: VFile) => undefined
import rehypeKatex
Render elements with a language-math
(or math-display
, math-inline
) class with KaTeX.
- @param options Configuration (optional).
- @returns Transform.
(alias) function remarkFrontmatter(options?: Options | null | undefined): undefined
import remarkFrontmatter
Add support for frontmatter.
Notes
Doesn’t parse the data inside them: create your own plugin to do that.
- @param options Configuration (default:
'yaml'
). - @returns Nothing.
(alias) function remarkGfm(options?: Options | null | undefined): undefined
import remarkGfm
Add support GFM (autolink literals, footnotes, strikethrough, tables, tasklists).
- @param options Configuration (optional).
- @returns Nothing.
(alias) function remarkMath(options?: Readonly<Options> | null | undefined): undefined
import remarkMath
Add support for math.
- @param options Configuration (optional).
- @returns Nothing.
const file: "# hi"
(alias) compile(vfileCompatible: any, compileOptions?: Readonly<CompileOptions> | null | undefined): Promise<VFile>
import compile
Compile MDX to JS.
- @param vfileCompatible MDX document to parse.
- @param compileOptions Compile configuration (optional).
- @return Promise to compiled file.
const file: "# hi"
(property) remarkPlugins?: PluggableList | null | undefined
List of remark plugins (optional).
(alias) function remarkGfm(options?: Options | null | undefined): undefined
import remarkGfm
Add support GFM (autolink literals, footnotes, strikethrough, tables, tasklists).
- @param options Configuration (optional).
- @returns Nothing.
(alias) compile(vfileCompatible: any, compileOptions?: Readonly<CompileOptions> | null | undefined): Promise<VFile>
import compile
Compile MDX to JS.
- @param vfileCompatible MDX document to parse.
- @param compileOptions Compile configuration (optional).
- @return Promise to compiled file.
const file: "# hi"
(property) remarkPlugins?: PluggableList | null | undefined
List of remark plugins (optional).
(alias) function remarkFrontmatter(options?: Options | null | undefined): undefined
import remarkFrontmatter
Add support for frontmatter.
Notes
Doesn’t parse the data inside them: create your own plugin to do that.
- @param options Configuration (default:
'yaml'
). - @returns Nothing.
(alias) compile(vfileCompatible: any, compileOptions?: Readonly<CompileOptions> | null | undefined): Promise<VFile>
import compile
Compile MDX to JS.
- @param vfileCompatible MDX document to parse.
- @param compileOptions Compile configuration (optional).
- @return Promise to compiled file.
const file: "# hi"
(property) remarkPlugins?: PluggableList | null | undefined
List of remark plugins (optional).
(alias) function remarkGfm(options?: Options | null | undefined): undefined
import remarkGfm
Add support GFM (autolink literals, footnotes, strikethrough, tables, tasklists).
- @param options Configuration (optional).
- @returns Nothing.
(alias) function remarkFrontmatter(options?: Options | null | undefined): undefined
import remarkFrontmatter
Add support for frontmatter.
Notes
Doesn’t parse the data inside them: create your own plugin to do that.
- @param options Configuration (default:
'yaml'
). - @returns Nothing.
(alias) compile(vfileCompatible: any, compileOptions?: Readonly<CompileOptions> | null | undefined): Promise<VFile>
import compile
Compile MDX to JS.
- @param vfileCompatible MDX document to parse.
- @param compileOptions Compile configuration (optional).
- @return Promise to compiled file.
const file: "# hi"
(property) remarkPlugins?: PluggableList | null | undefined
List of remark plugins (optional).
(alias) function remarkGfm(options?: Options | null | undefined): undefined
import remarkGfm
Add support GFM (autolink literals, footnotes, strikethrough, tables, tasklists).
- @param options Configuration (optional).
- @returns Nothing.
(property) singleTilde: boolean
(alias) function remarkFrontmatter(options?: Options | null | undefined): undefined
import remarkFrontmatter
Add support for frontmatter.
Notes
Doesn’t parse the data inside them: create your own plugin to do that.
- @param options Configuration (default:
'yaml'
). - @returns Nothing.
(alias) compile(vfileCompatible: any, compileOptions?: Readonly<CompileOptions> | null | undefined): Promise<VFile>
import compile
Compile MDX to JS.
- @param vfileCompatible MDX document to parse.
- @param compileOptions Compile configuration (optional).
- @return Promise to compiled file.
const file: "# hi"
(property) rehypePlugins?: PluggableList | null | undefined
List of rehype plugins (optional).
(alias) function rehypeKatex(options?: Readonly<Options> | null | undefined): (tree: Root, file: VFile) => undefined
import rehypeKatex
Render elements with a language-math
(or math-display
, math-inline
) class with KaTeX.
- @param options Configuration (optional).
- @returns Transform.
(property) remarkPlugins?: PluggableList | null | undefined
List of remark plugins (optional).
(alias) function remarkMath(options?: Readonly<Options> | null | undefined): undefined
import remarkMath
Add support for math.
- @param options Configuration (optional).
- @returns Nothing.
(alias) compile(vfileCompatible: any, compileOptions?: Readonly<CompileOptions> | null | undefined): Promise<VFile>
import compile
Compile MDX to JS.
- @param vfileCompatible MDX document to parse.
- @param compileOptions Compile configuration (optional).
- @return Promise to compiled file.
const file: "# hi"
(property) rehypePlugins?: PluggableList | null | undefined
List of rehype plugins (optional).
(alias) function rehypeKatex(options?: Readonly<Options> | null | undefined): (tree: Root, file: VFile) => undefined
import rehypeKatex
Render elements with a language-math
(or math-display
, math-inline
) class with KaTeX.
- @param options Configuration (optional).
- @returns Transform.
(property) strict: boolean
(property) throwOnError: boolean
(property) remarkPlugins?: PluggableList | null | undefined
List of remark plugins (optional).
(alias) function remarkMath(options?: Readonly<Options> | null | undefined): undefined
import remarkMath
Add support for math.
- @param options Configuration (optional).
- @returns Nothing.
创建插件
¥Creating plugins
为 MDX 创建插件与为 remark 或 rehype 创建插件基本相同。§ 在 unifiedjs.com
上学习 中有一些关于这方面的指南和秘诀。
¥Creating a plugin for MDX is mostly the same as creating a plugin for remark or rehype. There are several guides and recipes on that in § Learn on unifiedjs.com
.
对于插件的 MDX 特定部分,建议阅读 ¶ 架构 以了解 @mdx-js/mdx
的工作原理。有关代表 MDX 特定功能的节点类型的信息,请参阅 ¶ remark-mdx
中的语法树 并使用我们的交互式 § 在线运行。
¥For the MDX specific parts of plugins, it’s recommended to read ¶ Architecture to learn how @mdx-js/mdx
works. For info on the node types that represent MDX specific features, see ¶ Syntax tree in remark-mdx
and use our interactive § Playground.