UNIAPP使用MathJax解析数学公式

2024-06-13 19:08

本文主要是介绍UNIAPP使用MathJax解析数学公式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

近期有个需求,将之前后台录入的MathJax公式解析展示到APP中,研究了一下论坛里的代码,最终实现了需求,将代码和遇到的问题整理一下发出来,分享一下经验。

实现的效果图在下面附件中,目前**只测试过安卓APP,H5和苹果APP未测试**


核心代码如下:
因为目前只有一个页面使用数学公式,所以未封装,多个页面需要的话可以自行封装一个JS。
将代码完整的复制到vue页面里即可使用

HTML代码:

此时可以不用v-html,我用v-html是因为公式中还含有html元素,execQuestionContent方法的作用是处理斜杠,如果公式正确可以不用,方法代码在下方图中,有需要的可以参考


<view class="problem-content-title" v-html="execQuestionContent(item.questionDto.question.question)"> </view>

此处script代码块需要单独另写一个,不需要跟原来的script重合,复制到vue页面最下方即可。

<script module="MathJax" lang="renderjs">export default {mounted() {let that = this;if (typeof window.MathJax === 'object') {that.initMathJax()} else {const script = document.createElement('script')//MathJax地址,为保持稳定可以下载到自己的服务器上引用,注意config参数不可忽略script.src = 'https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.7/MathJax.js?config=TeX-MML-AM_CHTML'script.onload = that.initMathJax.bind(that);document.head.appendChild(script)}},methods: {initMathJax() {MathJax.Hub.Config({showProcessingMessages: false, //关闭js加载过程信息messageStyle: "none", //不显示信息jax: ["input/TeX", "output/HTML-CSS"],tex2jax: {inlineMath: [["$", "$"],["\\(", "\\)"]], //行内公式选择符displayMath: [ ["$$", "$$"],["\\[", "\\]"]], //段内公式选择符skipTags: ["script", "noscript", "style", "textarea", "pre", "code", "a"] //避开某些标签},"HTML-CSS": {availableFonts: ["STIX", "TeX"], //可选字体showMathMenu: false //关闭右击菜单显示}});this.MathQueue();},MathQueue: function() {if (!window.MathJax) {return;}//container 是当前页面DOM的ID,可以自定义window.MathJax.Hub.Queue(["Typeset", window.MathJax.Hub, document.getElementById('container')]);}}}
</script>


遇到的问题:
1、执行后公式没有变化
排查原因:
1、排查公式是否符合inlineMath、displayMath选择符匹配标准,例如\\\\( 对应公式里的  \\(, \\\\\\\\(对应\\\\(,此处是决定能否匹配数学公式的关键,需要注意。
注:我的数据库之前存储的是\\\\\\\\(,这时候需要手动处理成 \\( ,然后再用 \\\\( 来匹配
例子如下:
 数学公式:函数\\\\(a{{x}^{2}}+5x+b&gt;0\\\\)的解集为\\\\(\\\\left\\\\{ x\\\\left| \\\\frac{1}{3} 
 我通过String.raw({ raw: content })处理后变成\\\\(,最后通过replace(/\\\\/g,'\\')变成\\(

2、src地址里面要带config=TeX-MML-AM_CHTML参数,不可以不带


如果还能不能转换,请留言问题和代码,我看到会第一时间回复。

这篇关于UNIAPP使用MathJax解析数学公式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1058172

相关文章

Go语言使用Gin处理路由参数和查询参数

《Go语言使用Gin处理路由参数和查询参数》在WebAPI开发中,处理路由参数(PathParameter)和查询参数(QueryParameter)是非常常见的需求,下面我们就来看看Go语言... 目录一、路由参数 vs 查询参数二、Gin 获取路由参数和查询参数三、示例代码四、运行与测试1. 测试编程路

Python使用python-pptx自动化操作和生成PPT

《Python使用python-pptx自动化操作和生成PPT》这篇文章主要为大家详细介绍了如何使用python-pptx库实现PPT自动化,并提供实用的代码示例和应用场景,感兴趣的小伙伴可以跟随小编... 目录使用python-pptx操作PPT文档安装python-pptx基础概念创建新的PPT文档查看

C#和Unity中的中介者模式使用方式

《C#和Unity中的中介者模式使用方式》中介者模式通过中介者封装对象交互,降低耦合度,集中控制逻辑,适用于复杂系统组件交互场景,C#中可用事件、委托或MediatR实现,提升可维护性与灵活性... 目录C#中的中介者模式详解一、中介者模式的基本概念1. 定义2. 组成要素3. 模式结构二、中介者模式的特点

MySQL中优化CPU使用的详细指南

《MySQL中优化CPU使用的详细指南》优化MySQL的CPU使用可以显著提高数据库的性能和响应时间,本文为大家整理了一些优化CPU使用的方法,大家可以根据需要进行选择... 目录一、优化查询和索引1.1 优化查询语句1.2 创建和优化索引1.3 避免全表扫描二、调整mysql配置参数2.1 调整线程数2.

C#中SortedSet的具体使用

《C#中SortedSet的具体使用》SortedSet是.NETFramework4.0引入的一个泛型集合类,它实现了一个自动排序的集合,内部使用红黑树数据结构来维护元素的有序性,下面就来介绍一下如... 目录基础概念主要特性创建和初始化基本创建方式自定义比较器基本操作添加和删除元素查询操作范围查询集合运

C# Opacity 不透明度的具体使用

《C#Opacity不透明度的具体使用》本文主要介绍了C#Opacity不透明度的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录WinFormsOpacity以下是一些使用Opacity属性的示例:设置窗体的透明度:设置按钮的透

99%的人都选错了! 路由器WiFi双频合一还是分开好的专业解析与适用场景探讨

《99%的人都选错了!路由器WiFi双频合一还是分开好的专业解析与适用场景探讨》关于双频路由器的“双频合一”与“分开使用”两种模式,用户往往存在诸多疑问,本文将从多个维度深入探讨这两种模式的优缺点,... 在如今“没有WiFi就等于与世隔绝”的时代,越来越多家庭、办公室都开始配置双频无线路由器。但你有没有注

Python中的sort()和sorted()用法示例解析

《Python中的sort()和sorted()用法示例解析》本文给大家介绍Python中list.sort()和sorted()的使用区别,详细介绍其参数功能及Timsort排序算法特性,涵盖自适应... 目录一、list.sort()参数说明常用内置函数基本用法示例自定义函数示例lambda表达式示例o

Go语言使用net/http构建一个RESTful API的示例代码

《Go语言使用net/http构建一个RESTfulAPI的示例代码》Go的标准库net/http提供了构建Web服务所需的强大功能,虽然众多第三方框架(如Gin、Echo)已经封装了很多功能,但... 目录引言一、什么是 RESTful API?二、实战目标:用户信息管理 API三、代码实现1. 用户数据

在ASP.NET项目中如何使用C#生成二维码

《在ASP.NET项目中如何使用C#生成二维码》二维码(QRCode)已广泛应用于网址分享,支付链接等场景,本文将以ASP.NET为示例,演示如何实现输入文本/URL,生成二维码,在线显示与下载的完整... 目录创建前端页面(Index.cshtml)后端二维码生成逻辑(Index.cshtml.cs)总结