兴起开发博客,硬控两天两夜,做了个LaTeX的Vue3渲染小组件

契机

正在丰富我自己的博客的时候忽然灵机一动。

哎,你说我要是向博客里加入 <math xmlns="http://www.w3.org/1998/Math/MathML"> LaTeX \LaTeX </math>LATEX 功能的支持会不会很酷

然后搜了搜 Vue 的 LaTeX 插件,却不是很尽如人意

MathJax 虽然有 Vue3 版本,但其不支持 ES6 且页面动态重渲染的调度我认为不太满足我博客的需求,而 KaTeX 原生的用法是比较复杂的

于是我寻找一些 KaTeX 的非官方插件

找到了两个:vue-katexVaTex

其中 vue-katex 是 Vue2 版本的,直接放弃,VaTex 的作者在 知乎 发表过文章,看了看文章,看了看源码,还是放弃了

先说说优点:完美符合我的想法,开箱即用

html 复制代码
<vue-latex :expression="'\frac{a_i}{1+x}'" display-mode />

但是我认为的不足也有很多

  1. 不支持很多 KaTeX 官方支持的选项,比如 leqno 模式
  2. 没有做渲染上面的优化
  3. 不支持组件功能的全局调节

故下决心自己开发一个插件

成果

于是花费不到两天时间,我的 KaTeX Vue3 插件诞生了 ── Katex Vue

完全响应式,完全开箱即用,完全支持 KaTeX 原有选项配置

用法

1. 安装

bash 复制代码
pnpm add -D katex katex-vue

或使用 npmyarnbun 替换 pnpm 以适配您项目的包管理器

2. 使用

html 复制代码
<script setup>
  import { KatexVue } from 'katex-vue'
  const expression = "\\int_0^\\infty x^2 \\mathrm{d} x"
</script>

<template>
  <katex-vue :expression="expression" displayMode />
</template>

同样开箱即用

3. 配置

配置项

Prop Type Default
expression String (必须值) -
displayMode Boolean false
output 'mathml' / 'html' / 'htmlAndMathml' 'htmlAndMathml'
leqno Boolean false
fleqn Boolean false
throwOnError Boolean false
errorColor String '#cc0000'
macros Object -
minRuleThickness Number -
colorIsTextColor Boolean false
maxSize Number Infinity
maxExpand Number 1000
strict Boolean / 'warn' / 'error' / 'ignore' / Function 'warn'
trust Boolean false
globalGroup Boolean false

详细请见 KaTeX 文档

可在 main.ts 中设置全局配置

ts 复制代码
import {createApp} from 'vue'
import KatexVue from 'katex-vue'

const app = createApp()
app.use(KatexVue, {
    // 在此处设置您的全局配置
    displayMode: true,
    errorColor: '#ff5500'
})
app.mount('#app')

设置组件配置

html 复制代码
<template>
  <katex-vue
      expression="\int_0^1x^2\mathrm{d}x"
      displayMode
      output="mathml"
      ...
  />
</template>

自我批评

这个插件还有很多未完成(或者说我想要完成的内容),比如:

  • 防抖处理
  • 渲染缓存
  • 等等......

但是毕竟学业为主,精力不够还望谅解

最近会在周末等空闲时间对其进行进一步的开发的 QwQ

尾声

我还是一个大二在校学生,这也是第一次对前端开源社区做了自己的一点微不足道的贡献,同时不懂的地方也有很多,如果有任何问题欢迎来讨论,有什么使用起来不爽的随意喷我

github issue pr 尽管提

以及可以来看一下个人博客捏~

相关推荐
海天胜景2 小时前
vue3 el-table动态表头
javascript·vue.js·elementui
鱼樱前端6 小时前
2025前端人一文看懂 Broadcast Channel API 通信指南
前端·vue.js
鱼樱前端6 小时前
2025前端人一文看懂 window.postMessage 通信
前端·vue.js
浮桥9 小时前
vue3实现pdf文件预览 - vue-pdf-embed
前端·vue.js·pdf
AA-代码批发V哥10 小时前
Vue框架之钩子函数详解
vue.js
四季豆豆豆10 小时前
博客项目 laravel vue mysql 第四章 分类功能
vue.js·mysql·laravel
拾光拾趣录11 小时前
Vue中v-if与v-for同元素使用的陷阱
前端·vue.js
江城开朗的豌豆14 小时前
退出登录后头像还在?这个缓存问题坑过多少前端!
前端·javascript·vue.js
江城开朗的豌豆14 小时前
Vue的'读心术':它怎么知道数据偷偷变了?
前端·javascript·vue.js
江城开朗的豌豆15 小时前
手把手教你造一个自己的v-model:原来双向绑定这么简单!
前端·javascript·vue.js