Guides / Math
This guide explores how to support math (LaTeX) in MDX. MDX supports standard markdown syntax (CommonMark). That means math is not supported by default. Math can be enabled by using a remark plugin: remark-math
, combined with a rehype plugin: either rehype-katex
(KaTeX) or rehype-mathjax
(MathJax). Like other remark and rehype plugins, they can be passed in remarkPlugins
and rehypePlugins
, respectively, in ProcessorOptions
. More info on plugins is available in § Extending MDX
Say we have an MDX file like this:
# $$\sqrt{a^2 + b^2}$$
The above MDX with math can be transformed with the following module:
import fs from 'node:fs/promises'
import {compile} from '@mdx-js/mdx'
import rehypeKatex from 'rehype-katex'
import remarkMath from 'remark-math'
console.log(
String(
await compile(await fs.readFile('example.mdx'), {
rehypePlugins: [rehypeKatex],
remarkPlugins: [remarkMath]
})
)
)
<>
<h1>
<span className="katex">
<span className="katex-mathml">
<math xmlns="http://www.w3.org/1998/Math/MathML">…</math>
</span>
<span className="katex-html" aria-hidden="true">
…
</span>
</span>
</h1>
</>
Important: if you chose rehype-katex
, you should also use katex.css
somewhere on the page to style math properly. At the time of writing, the last version is:
<!-- Get the latest one from: https://katex.org/docs/browser -->
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/katex@0.16.10/dist/katex.min.css" integrity="sha384-wcIxkf4k558AjM3Yz3BBFQUbk/zgIYC2R0QpeeYb+TwlBVMrlgLqwRjRtGZiK7ww" crossorigin="anonymous">
To get the latest link to the stylesheet, go to katex docs
.
Note: see also remark-mdx-math-enhanced
, which you can use to support JavaScript expressions inside of math (such as to access properties or to make calculations)