mirror of
https://github.com/facebook/docusaurus.git
synced 2025-04-30 18:58:36 +02:00
148 lines
4.1 KiB
Text
148 lines
4.1 KiB
Text
---
|
|
id: math-equations
|
|
description: Writing LaTeX Math Equations
|
|
slug: /markdown-features/math-equations
|
|
---
|
|
|
|
# Math Equations
|
|
|
|
import BrowserWindow from '@site/src/components/BrowserWindow';
|
|
|
|
Mathematical equations can be rendered using [KaTeX](https://katex.org).
|
|
|
|
## Usage {#usage}
|
|
|
|
Please read [KaTeX](https://katex.org) documentation for more details.
|
|
|
|
### Inline {#inline}
|
|
|
|
Write inline math equations by wrapping LaTeX equations between `$`:
|
|
|
|
```latex
|
|
Let $f\colon[a,b]\to\R$ be Riemann integrable. Let $F\colon[a,b]\to\R$ be
|
|
$F(x)=\int_{a}^{x} f(t)\,dt$. Then $F$ is continuous, and at all $x$ such that
|
|
$f$ is continuous at $x$, $F$ is differentiable at $x$ with $F'(x)=f(x)$.
|
|
```
|
|
|
|
<BrowserWindow>
|
|
|
|
Let $f\colon[a,b] \to \R$ be Riemann integrable. Let $F\colon[a,b]\to\R$ be $F(x)=
|
|
\int_{a}^{x} f(t)\,dt$. Then $F$ is continuous, and at all $x$ such that $f$ is continuous at $x$, $F$ is differentiable at $x$ with $F'(x)=f(x)$.
|
|
|
|
</BrowserWindow>
|
|
|
|
### Blocks {#blocks}
|
|
|
|
For equation block or display mode, use line breaks and `$$`:
|
|
|
|
```latex
|
|
$$
|
|
I = \int_0^{2\pi} \sin(x)\,dx
|
|
$$
|
|
```
|
|
|
|
<BrowserWindow>
|
|
|
|
$$
|
|
I = \int_0^{2\pi} \sin(x)\,dx
|
|
$$
|
|
|
|
</BrowserWindow>
|
|
|
|
## Configuration {#configuration}
|
|
|
|
To enable KaTeX, you need to install `remark-math` and `rehype-katex` plugins.
|
|
|
|
```bash npm2yarn
|
|
npm install --save remark-math@5 rehype-katex@6
|
|
```
|
|
|
|
:::caution
|
|
|
|
Make sure to use `remark-math >= 5` and `rehype-katex >= 6` for Docusaurus v3 (using MDX v2).
|
|
|
|
:::
|
|
|
|
Those 2 plugins are now only available as ESM packages, and you will need to import them dynamically.
|
|
|
|
First, turn your site config into an async config creator function:
|
|
|
|
```js title="docusaurus.config.js"
|
|
module.exports = async function createConfigAsync() {
|
|
return {
|
|
// your site config...
|
|
};
|
|
};
|
|
```
|
|
|
|
It is now possible to import the plugins dynamically and add them to your content plugin or preset options (usually `@docusaurus/preset-classic` docs options):
|
|
|
|
```js
|
|
remarkPlugins: [(await import('remark-math')).default],
|
|
rehypePlugins: [(await import('rehype-katex')).default],
|
|
```
|
|
|
|
Include the KaTeX CSS in your config under `stylesheets`:
|
|
|
|
```js
|
|
stylesheets: [
|
|
{
|
|
href: 'https://cdn.jsdelivr.net/npm/katex@0.13.24/dist/katex.min.css',
|
|
type: 'text/css',
|
|
integrity:
|
|
'sha384-odtC+0UGzzFL/6PNoE8rX/SPcQDXBJ+uRepguP4QkPCm2LBxH3FA3y+fKSiJ+AmM',
|
|
crossorigin: 'anonymous',
|
|
},
|
|
],
|
|
```
|
|
|
|
Overall the changes look like:
|
|
|
|
```js title="docusaurus.config.js"
|
|
module.exports = async function createConfigAsync() {
|
|
return {
|
|
title: 'Docusaurus',
|
|
tagline: 'Build optimized websites quickly, focus on your content',
|
|
presets: [
|
|
[
|
|
'@docusaurus/preset-classic',
|
|
{
|
|
docs: {
|
|
path: 'docs',
|
|
// highlight-start
|
|
remarkPlugins: [(await import('remark-math')).default],
|
|
rehypePlugins: [(await import('rehype-katex')).default],
|
|
// highlight-end
|
|
},
|
|
},
|
|
],
|
|
],
|
|
// highlight-start
|
|
stylesheets: [
|
|
{
|
|
href: 'https://cdn.jsdelivr.net/npm/katex@0.13.24/dist/katex.min.css',
|
|
type: 'text/css',
|
|
integrity:
|
|
'sha384-odtC+0UGzzFL/6PNoE8rX/SPcQDXBJ+uRepguP4QkPCm2LBxH3FA3y+fKSiJ+AmM',
|
|
crossorigin: 'anonymous',
|
|
},
|
|
],
|
|
// highlight-end
|
|
};
|
|
};
|
|
```
|
|
|
|
## Self-hosting KaTeX assets {#self-hosting-katex-assets}
|
|
|
|
Loading stylesheets, fonts, and JavaScript libraries from CDN sources is a good practice for popular libraries and assets, since it reduces the amount of assets you have to host. In case you prefer to self-host the `katex.min.css` (along with required KaTeX fonts), you can download the latest version from [KaTeX GitHub releases](https://github.com/KaTeX/KaTeX/releases), extract and copy `katex.min.css` and `fonts` directory (only `.woff2` font types should be enough) to your site's `static` directory, and in `docusaurus.config.js`, replace the stylesheet's `href` from the CDN URL to your local path (say, `/katex/katex.min.css`).
|
|
|
|
```js title="docusaurus.config.js"
|
|
module.exports = {
|
|
stylesheets: [
|
|
{
|
|
href: '/katex/katex.min.css',
|
|
type: 'text/css',
|
|
},
|
|
],
|
|
};
|
|
```
|