从 MathJax 2.7.5 升级到 3.0,试图保留自定义的 TeX 环境
Upgrading from MathJax 2.7.5 to 3.0, trying to preserve a custom TeX environment
我在 GitHub 页面上将 MathJax 与我的 Jekyll 博客一起使用。事实上,我写了一篇博客 post,详细介绍了我设置 MathJax 2.7.5 所采取的具体步骤:"MathJax in Jekyll"(2018 年 8 月)
对于几个 post,我想使用 psmallmatrix
环境,例如 mathtools
包中的环境:$$\begin{psmallmatrix} 1 \ 0 \end{psmallmatrix}$$
。我知道如何使用 \newenvironment
命令在实际的 TeX 中创建这样的环境:"How do I make a small pmatrix?"
但是为了在 MathJax 2.7.5 中“预加载”命令,我这样做了,从 MathJax 版本的 AMSmath 包中提取了一些代码:
<script type="text/x-mathjax-config">
MathJax.Hub.Config({
extensions: [
"MathMenu.js",
"MathZoom.js",
"AssistiveMML.js",
"a11y/accessibility-menu.js"
],
jax: ["input/TeX", "output/CommonHTML"],
TeX: {
extensions: [
"AMSmath.js",
"AMSsymbols.js",
"noErrors.js",
"noUndefined.js",
]
}
});
MathJax.Hub.Register.StartupHook("TeX Jax Ready",function () {
var TEX = MathJax.InputJax.TeX;
var COLS = function (W) {
var WW = [];
for (var i = 0, m = W.length; i < m; i++)
{WW[i] = TEX.Parse.prototype.Em(W[i])}
return WW.join(" ");
};
TEX.Definitions.Add({
environment: {
psmallmatrix: ['Array',null,'(',')','c',COLS([1/3]),".2em",'S',1],
}
});
});
</script>
<script type="text/javascript" async
src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/latest.js">
</script>
在过去一年左右的某个时候,MathJax 2.7.5 完全停止了 GitHub,所以我正在尝试升级到 MathJax 3.0。
我已经使用 MathJax's own config converter 设法翻译了这个配置的非棘手部分,但我不知道如何处理我手工制作的 psmallmatrix
。
这是我现在拥有的:
<script type="text/javascript">
window.MathJax = {
tex: {
packages: ['base', 'ams'],
},
loader: {
load: ['ui/menu', '[tex]/ams'],
},
};
</script>
<script type="text/javascript" id="MathJax-script" async
src="https://cdn.jsdelivr.net/npm/mathjax@3/es5/tex-chtml.js">
</script>
如何在 MathJax 3.0 中恢复我手工制作的 psmallmatrix
环境?格式只需要大致相同,只要我可以用 \begin{psmallmatrix}
.
继续调用它
我应该提到 the MathJax docs on "Defining TeX Macros" 给出了一个例子,说明如何使用宏“预加载”TeX 解析器,大致相当于 \newcommand
所做的。文档说:
window.MathJax = {
tex: {
macros: {
RR: "{\bf R}",
bold: ["{\bf #1}", 1]
}
}
};
但是文档缺少任何关于如何为 \newenvironment
做同样事情的例子。
下面是将psmallmatrix
环境添加到AMS环境列表的配置。 pre-configure 环境应该有一种类似于宏的方法。我在 MathJax GitHub 存储库中为它制作了 feature request。
现在,添加
<script>
MathJax = {
startup: {
ready() {
MathJax.startup.defaultReady();
const Macro = MathJax._.input.tex.Symbol.Macro;
const MapHandler = MathJax._.input.tex.MapHandler.MapHandler;
const Array = MathJax._.input.tex.ams.AmsMethods.AmsMethods.Array;
const env = new Macro('psmallmatrix', Array, [null,'(',')','c','.333em','.2em','S',1]);
MapHandler.getMap('AMSmath-environment').add('psmallmatrix', env);
}
}
};
</script>
作为启用 psmallmatrix
环境的配置。
我在 GitHub 页面上将 MathJax 与我的 Jekyll 博客一起使用。事实上,我写了一篇博客 post,详细介绍了我设置 MathJax 2.7.5 所采取的具体步骤:"MathJax in Jekyll"(2018 年 8 月)
对于几个 post,我想使用 psmallmatrix
环境,例如 mathtools
包中的环境:$$\begin{psmallmatrix} 1 \ 0 \end{psmallmatrix}$$
。我知道如何使用 \newenvironment
命令在实际的 TeX 中创建这样的环境:"How do I make a small pmatrix?"
但是为了在 MathJax 2.7.5 中“预加载”命令,我这样做了,从 MathJax 版本的 AMSmath 包中提取了一些代码:
<script type="text/x-mathjax-config">
MathJax.Hub.Config({
extensions: [
"MathMenu.js",
"MathZoom.js",
"AssistiveMML.js",
"a11y/accessibility-menu.js"
],
jax: ["input/TeX", "output/CommonHTML"],
TeX: {
extensions: [
"AMSmath.js",
"AMSsymbols.js",
"noErrors.js",
"noUndefined.js",
]
}
});
MathJax.Hub.Register.StartupHook("TeX Jax Ready",function () {
var TEX = MathJax.InputJax.TeX;
var COLS = function (W) {
var WW = [];
for (var i = 0, m = W.length; i < m; i++)
{WW[i] = TEX.Parse.prototype.Em(W[i])}
return WW.join(" ");
};
TEX.Definitions.Add({
environment: {
psmallmatrix: ['Array',null,'(',')','c',COLS([1/3]),".2em",'S',1],
}
});
});
</script>
<script type="text/javascript" async
src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/latest.js">
</script>
在过去一年左右的某个时候,MathJax 2.7.5 完全停止了 GitHub,所以我正在尝试升级到 MathJax 3.0。
我已经使用 MathJax's own config converter 设法翻译了这个配置的非棘手部分,但我不知道如何处理我手工制作的 psmallmatrix
。
这是我现在拥有的:
<script type="text/javascript">
window.MathJax = {
tex: {
packages: ['base', 'ams'],
},
loader: {
load: ['ui/menu', '[tex]/ams'],
},
};
</script>
<script type="text/javascript" id="MathJax-script" async
src="https://cdn.jsdelivr.net/npm/mathjax@3/es5/tex-chtml.js">
</script>
如何在 MathJax 3.0 中恢复我手工制作的 psmallmatrix
环境?格式只需要大致相同,只要我可以用 \begin{psmallmatrix}
.
我应该提到 the MathJax docs on "Defining TeX Macros" 给出了一个例子,说明如何使用宏“预加载”TeX 解析器,大致相当于 \newcommand
所做的。文档说:
window.MathJax = {
tex: {
macros: {
RR: "{\bf R}",
bold: ["{\bf #1}", 1]
}
}
};
但是文档缺少任何关于如何为 \newenvironment
做同样事情的例子。
下面是将psmallmatrix
环境添加到AMS环境列表的配置。 pre-configure 环境应该有一种类似于宏的方法。我在 MathJax GitHub 存储库中为它制作了 feature request。
现在,添加
<script>
MathJax = {
startup: {
ready() {
MathJax.startup.defaultReady();
const Macro = MathJax._.input.tex.Symbol.Macro;
const MapHandler = MathJax._.input.tex.MapHandler.MapHandler;
const Array = MathJax._.input.tex.ams.AmsMethods.AmsMethods.Array;
const env = new Macro('psmallmatrix', Array, [null,'(',')','c','.333em','.2em','S',1]);
MapHandler.getMap('AMSmath-environment').add('psmallmatrix', env);
}
}
};
</script>
作为启用 psmallmatrix
环境的配置。