# katex-mini
**Repository Path**: rojerchen/katex-mini
## Basic Information
- **Project Name**: katex-mini
- **Description**: 在微信小程序上渲染Latex公式(不依赖服务端渲染,使用KaTeX)
- **Primary Language**: Unknown
- **License**: Not specified
- **Default Branch**: master
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 12
- **Forks**: 7
- **Created**: 2022-03-19
- **Last Updated**: 2025-09-08
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
# katex-weapp
基于 KaTeX 构建的小程序原生 LaTeX 渲染组件(不依赖服务端渲染)
## 效果预览图

## 实现原理
基于 katex 库,解析 latex 公式生成虚拟 dom 树对象,将 dom 对象翻译成小程序的 rich-text 支持的 nodes 由小程序渲染
### 局限性
- 依赖微信小程序的 `rich-text` 组件渲染,请注意小程序基础库 1.4.0 开始支持
- 由于 katex 库过大会大量占用小程序包体大小。
### 包体过大解决方式
- 【推荐】使用小程序分包:[小程序分包文档](https://developers.weixin.qq.com/miniprogram/dev/framework/subpackages.html)
- 【不推荐】如果你希望再小一点,可以将解析模块放在服务端,提供解析接口,再将结果展示在 rich-text 中(已实现)`虽然这里使用了服务端,但是这里是产出json格式的nodes而非图片,相对于将latex转为图片的方案也好很多`
## 【试验性】1.3.0 起支持 Katex 中类似 Auto-render 渲染方式
自`1.3.0`起,支持呈现文本中的所有数学,用法如下:
```ts
import { renderMathInText } from "@rojer/katex-mini";
const innerMathText =
"这是一个行内公式 $ f(x) = sum_{n=0}^{infty} \\frac{f^{(n)}(a)}{n!} (x - a)^n $ ,这是一个行间的公式 $$ \\int_a^b f(x) , dx = F(b) - F(a) $$ \n这是新起一行的文字";
const nodes = renderMathInText(innerMathText, {
delimiters: [
{ left: "$$", right: "$$", display: true },
{ left: "$", right: "$", display: false },
],
});
// 将渲染得到的nodes交给小程序RichText组件渲染
this.setData({
nodes,
});
```
> `renderMathInText` 的 参数参考: https://katex.org/docs/autorender#api
效果预览图:
| 小程序效果 |
| -------- |
|  |
## 有没有完整题目编排方案?
DSlate 富文本编辑器 :支持 Latex、图文、混合编排的编辑器,可以直接导出小程序 rich-text 支持格式的 JSON 数据。[DEMO](https://rojer95.github.io/dslate/getting-started/math)
预览图:
| 编辑器 | 小程序效果 |
| -------- | -------- |
|  |  |
## 如何使用?
### 在原生小程序项目中直接使用
#### 1. 在小程序中安装依赖
```bash
npm install @rojer/katex-mini
```
#### 安装 katex (@rojer/katex-mini@1.2.0 之后需要手动安装)
> ⚠️ 自 1.2.0 版本起,`@rojer/katex-mini`不再包含`katex`,因此你需要自行安装`katex`
```bash
npm install katex
```
#### 2. 在小程序开发者工具中 - 工具 - 构建 npm,执行后会看到生成的`miniprogram_npm`目录
#### 3. 在 `app.wxss` 加载 katex 的内置 css 样式
```less
@import "./miniprogram_npm/@rojer/katex-mini/index.wxss";
```
#### 4. 在小程序中解析 latex
```js
// index.js
import parse from "@rojer/katex-mini";
Page({
data: {
nodes: [],
latex:
"\\displaystyle \\frac{1}{\\Bigl(\\sqrt{\\phi \\sqrt{5}}-\\phi\\Bigr) e^{\\frac25 \\pi}} = 1+\\frac{e^{-2\\pi}} {1+\\frac{e^{-4\\pi}} {1+\\frac{e^{-6\\pi}} {1+\\frac{e^{-8\\pi}} {1+\\cdots} } } }",
},
onInput: function (e) {
this.setData({
latex: e.detail.value,
});
},
renderLatex: function () {
const katexOption = {
displayMode: true,
}; // 参考 katex 的配置
this.setData({
nodes: parse(this.data.latex, {
throwError: true, // 为true时,解析失败会抛出错误,否则会直接把错误信息解析为nodes结构展示
...katexOption,
}),
});
},
});
```
#### 5. 在页面中展示
```html
|
rojer |
had0ngzhu |