在 MathML 使用入门文章中,我们学习了用于描述分数的 <mfrac> 元素。现在让我们看一个基本示例,其中还添加了用于根号(<msqrt> 和 <mroot>)的新元素:
<math>
  <mfrac>
    <mtext>child1</mtext>
    <mtext>child2</mtext>
  </mfrac>
</math>
<br />
<math>
  <msqrt>
    <mtext>child1</mtext>
    <mtext>child2</mtext>
    <mtext>...</mtext>
    <mtext>childN</mtext>
  </msqrt>
</math>
<br />
<math>
  <mroot>
    <mtext>child1</mtext>
    <mtext>child2</mtext>
  </mroot>
</math>
下面是浏览器渲染的屏幕截图:

- 我们知道 <mfrac>元素被渲染为一个分数:第一个子元素(分子)被绘制于第二个子元素(分母)的上方,并由一条水平线分隔。
- <msqrt>被渲染为一个平方根:其子元素呈现为一个- <mrow>,前缀为根号√,并完全被一条横线覆盖。
- 最后,<mroot>元素被渲染为一个 n 次方根:第一个元素被根号符号覆盖,而第二个元素被用作根的次数,并作为前缀上标呈现。
这是一个简单的练习,旨在验证你是否理解了 MathML 子树与其可视化呈现之间的关系。该文档包含一个 MathML 公式,你需要标记所有与该 MathML 公式中的子树相对应的子树。完成后,你可以查看 MathML 公式的源代码,以验证它是否符合你的预期。
<!DOCTYPE html>
<html lang="zh-CN">
  <head>
    <meta charset="utf-8"/>
    <title>带数学字符的页面</title>
    <link rel="stylesheet" href="https://fred-wang.github.io/MathFonts/LatinModern/mathfonts.css">
  </head>
  <body>
  <p>
    <math>
    <mfrac id="mfrac1">
      <msqrt id="msqrt1">
        <mn>2</mn>
      </msqrt>
      <mroot id="mroot1">
        <mn>4</mn>
        <mn>3</mn>
      </mroot>
    </mfrac>
    <mo>+</mo>
    <mroot id="mroot2">
      <mn>5</mn>
      <mfrac id="mfrac2">
        <mn>6</mn>
        <mn>7</mn>
      </mfrac>
    </mroot>
    <mo>+</mo>
    <msqrt id="msqrt2">
      <mn>8</mn>
      <mo>−</mo>
      <mn>9</mn>
    </msqrt>
  </p>
  <ol id="options">
    <li>
      <input type="checkbox" data-comment="验证 mfrac 中子元素的顺序!">
      一个将 mroot 作为第一个子元素,将 msqrt 作为第二个子元素的 mfrac。
    </li>
    <li>
      <input type="checkbox" data-highlight="mroot2" data-comment="5 的七分之六次方根。">
      一个将 mn 作为第一个子元素,将 mfrac 作为第二个子元素的 mroot。
    </li>
    <li>
      <input type="checkbox" data-comment="该公式不包含任何带有分数的平方根!">
      一个包含 mfrac 元素的 msqrt。
    </li>
    <li>
      <input type="checkbox" data-comment="2 的平方根。" data-highlight="msqrt1">
      一个具有一个 mn 子元素的 msqrt。
    </li>
    <li>
      <input type="checkbox" data-comment="验证 mroot 中子元素的顺序!">
      一个将 mfrac 作为第一个子元素,将 mn 作为第二个子元素的 mroot。
    </li>
    <li>
      <input type="checkbox" data-comment="“8 减 9”的平方根。" data-highlight="msqrt2">
      一个具有以下子元素列表的 msqrt:mn、mo、mn。
    </li>
    <li>
      <input type="checkbox" data-comment="2 的平方根除以 4 的立方根。" data-highlight="mfrac1">
      一个将 msqrt 作为第一个子元素,将 mroot 作为第二个子元素的 mfrac。
    </li>
    <li>
      <input type="checkbox" data-comment="mfrac 必须恰好有两个子元素!">
      一个具有以下子元素列表的 mfrac:msqrt、mn、msqrt。
    </li>
    <li>
      <input type="checkbox" data-comment="mroot 必须恰好有两个子元素!">
      一个具有一个 mn 子元素的 mroot。
    </li>
    <li>
      <input type="checkbox" data-comment="6 除以 7。" data-highlight="mfrac2">
      一个具有两个 mn 子元素的 mfrac。
    </li>
    <li>
      <input type="checkbox" data-comment="该公式不包含超过两个数字的平方根!">
      一个具有五个 mn 子元素的 msqrt。
    </li>
    <li>
      <input type="checkbox" data-highlight="mroot1" data-comment="4 的立方根。">
      一个具有两个 mn 子元素的 mroot。
    </li>
  </ol>
  <p>
    <strong id="comment"></strong>
  </p>
  <p>
    <strong id="status"></strong>
  </p>
  </body>
math {
  font-family:
    Latin Modern Math,
    STIX Two Math;
  font-size: 200%;
}
math .highlight {
  background: pink;
}
math [id] .highlight {
  background: lightblue;
}
p {
  padding: 0.5em;
}
const options = document.getElementById("options");
const comment = document.getElementById("comment");
const checkboxes = Array.from(options.getElementsByTagName("input"));
const status = document.getElementById("status");
function verifyOption(checkbox) {
  let mathml = checkbox.dataset.highlight;
  if (mathml) {
    mathml = document.getElementById(mathml);
  }
  if (checkbox.checked) {
    comment.textContent = checkbox.dataset.comment;
    if (mathml) {
      mathml.classList.add("highlight");
    } else {
      checkbox.checked = false;
    }
  } else {
    comment.textContent = "";
    if (mathml) {
      mathml.classList.remove("highlight");
    }
  }
  const finished = checkboxes.every(
    (checkbox) => !!checkbox.checked === !!checkbox.dataset.highlight,
  );
  status.textContent = finished ? "恭喜,你选中了所有正确选项!" : "";
}
checkboxes.forEach((checkbox) => {
  checkbox.addEventListener("change", () => {
    verifyOption(checkbox);
  });
});
正如之前所见,<msqrt> 和 <mroot> 元素上的上横线会水平拉伸以覆盖其内容。但实际上根号符号 √ 也会拉伸以与其内容一样高。
<link
  rel="stylesheet"
  href="https://fred-wang.github.io/MathFonts/LatinModern/mathfonts.css" />
<math display="block">
  <mroot>
    <msqrt>
      <mfrac>
        <mn>1</mn>
        <mn>2</mn>
      </mfrac>
    </msqrt>
    <mn>3</mn>
  </mroot>
</math>
有些数学概念有时会使用类似分数的表示法,例如二项式系数或勒让德符号。对于这种不绘制横线的类似分数的表示法,可以在 <mfrac> 元素上附加 linethickness="0" 属性进行标记:
<link
  rel="stylesheet"
  href="https://fred-wang.github.io/MathFonts/LatinModern/mathfonts.css" />
<math display="block">
  <mrow>
    <mo>(</mo>
    <mfrac linethickness="0">
      <mn>3</mn>
      <mn>2</mn>
    </mfrac>
    <mo>)</mo>
  </mrow>
  <mo>=</mo>
  <mn>3</mn>
  <mo>≠</mo>
  <mfrac>
    <mn>3</mn>
    <mn>2</mn>
  </mfrac>
</math>
备注:虽然 linethickness 属性可以用于指定任意的线条粗细,但最好保持默认值,该值是根据数学字体中指定的参数计算得出的。
 
  
    
    在本文中,我们学习了如何使用 <mfrac>、<msqrt> 和 <mroot> 元素来构建分数和根式。我们注意到了这些元素的一些特殊功能,即分数和根号符号。我们还学习了如何使用 linethickness 属性绘制无横线的分数。在下一篇文章中,我们将继续介绍基本的数学符号,并学习上下标记的使用。