微信答题小程序支持latex公式显示解决方案

boyanx11小时前技术教程2

需求沟通:


解决方案:基于 KaTeX 构建的小程序原生 LaTeX 渲染组件(不依赖服务端渲染)。


效果预览图

实现原理

基于 katex 库,解析 latex 公式生成虚拟 dom 树对象,将 dom 对象翻译成小程序的 rich-text 支持的 nodes 由小程序渲染

局限性

  • 依赖微信小程序的 rich-text 组件渲染,请注意小程序基础库 1.4.0 开始支持
  • 由于 katex 库过大会大量占用小程序包体大小。


如何使用?

在原生小程序项目中直接使用

1. 在小程序中安装依赖

npm install @rojer/katex-mini

安装 katex (@rojer/katex-mini@1.2.0 之后需要手动安装)

自 1.2.0 版本起,@rojer/katex-mini不再包含katex,因此你需要自行安 装katex

npm install katex

2. 在小程序开发者工具中 - 工具 - 构建 npm,执行后会看到生成的miniprogram_npm目录

3. 在app.wxss加载 katex 的内置 css 样式

@import "./miniprogram_npm/@rojer/katex-mini/index.wxss";

4. 在小程序中解析 latex

// 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. 在页面中展示

<!--index.wxml-->
<view class="container">
  <rich-text nodes="{{nodes}}"></rich-text>
  <textarea value="{{latex}}" bindinput="onInput" maxlength="1400"></textarea>
  <button bindtap="renderLatex">渲染</button>
</view>

相关文章

想要无纸化学习?电子笔记软件推荐!

这个时代是信息爆炸的时代,一部手机、一台电脑,能让你接触到浩如烟海的信息。如何记录和管理在网络中不经意发现的好资源?恐怕只有电子笔记软件了。笔记软件推荐Microsoft OneNoteOneNote...

亲测有效!AI写论文网站从论文选题到论文初稿,高效写论文不再难

作为一名应届毕业生,在经历多次论文查重失败的至暗时刻后,我系统测试了五款主流AI论文生成软件。从操作简易程度,论文生成内容的专业性,知网,维普查重,生成的论文初稿等几方面进行测试。事实证明:真正专业的...

一个更快速简洁的Latex OCR工具:Rapid Latex OCR

一个将公式图像转为latex格式的工具,代码修改自LaTeX-OCR,模型已经全部转为ONNX格式,并对推理代码做了精简,推理速度更快,更容易部署。仓库只有基于ONNXRuntime或者OpenVIN...

pix2tex - 通过 OCR 将数学公式的图像转换为相应的 LaTeX 代码

大家好,又见面了,我是 GitHub 精选君!背景介绍在数学领域,将手写公式转换为 LaTeX 代码是一个常见的需求。然而,手动转换费时费力且容易出错。为解决这一问题,pix2tex 项目应运而生。该...

CSDN-Markdown更轻松地记录你的技术生活

欢迎使用CSDN-Markdown编辑器,开启博客全新体验!语法简洁,轻松编辑,所见即所得扩展简洁的语法代码块高亮图片链接和图片上传LaTex数学公式UML序列图和流程图离线写博客导入导出Markdo...

复杂公式转化代码,轻松在AI进行数学推理

目前我们已经能够将文档、图片等形式的资料输入给AI供其思考,然而,像我们这种搞科研的人经常会碰到一些数学问题,我们希望AI能够针对性地给我们提供公式的含义、推导过程、化简过程等。公式作为一种特殊的格式...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。