Featured image of post hugoでKaTeX(LaTeX風数式表示)を有効にする方法

hugoでKaTeX(LaTeX風数式表示)を有効にする方法

KaTeXとは

KaTeXは、LaTeX風の数式をHTMLで表示するためのjavascriptライブラリです。

具体的には下記のような数式を表示することができます。

$$f(x) = x^2 + x + 41$$

他にもLaTeX風な数式表示ライブラリもあるようですが、KaTeXはシンプルで高速と定評があるようです。

hugoへの導入方法

  1. hugoのフォルダ階層でlayouts/partials/math.htmlを新規作成します。

中身は下記の通りにしてください。

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/katex@0.16.4/dist/katex.min.css" integrity="sha384-vKruj+a13U8yHIkAyGgK1J3ArTLzrFGBbBc0tDp4ad/EyewESeXE/Iv67Aj8gKZ0" crossorigin="anonymous">
<script defer src="https://cdn.jsdelivr.net/npm/katex@0.16.4/dist/katex.min.js" integrity="sha384-PwRUT/YqbnEjkZO0zZxNqcxACrXe+j766U2amXcgMg5457rve2Y7I6ZJSm2A0mS4" crossorigin="anonymous"></script>
<script defer src="https://cdn.jsdelivr.net/npm/katex@0.16.4/dist/contrib/auto-render.min.js" integrity="sha384-+VBxd3r6XgURycqtZ117nYw44OOcIax56Z4dCRWbxyPt0Koah1uHoK0o4+/RRE05" crossorigin="anonymous"></script>
<script>
document.addEventListener("DOMContentLoaded", function() {
  renderMathInElement(
    document.body,
    {
      delimiters: [
        {left: "$$", right: "$$", display: true},
        {left: "\\[", right: "\\]", display: true},
        {left: "$", right: "$", display: false},
        {left: "\\(", right: "\\)", display: false}
      ]
    });
  });
</script>
  1. 次に既存のファイルlayouts/partials/extend_head.htmlに下記のコードを追加します。
1
2
3
{{ if or .Params.math .Site.Params.math }}
{{ partial "math.html" . }}
{{ end }}
  1. これでKaTeXを使う準備が整いました。

ページのfront matterにmath: trueを追加することで、KaTeXを有効にすることができます。

  1. あとはページ記事の本文に、数式をLaTeX風に書くだけです。
1
$$ e^{i \pi} = -1 $$

上記のように記述すると、下記のように表示されます。

$$ e^{i \pi} = -1 $$

参考

comments powered by Disqus
Hugo で構築されています。
テーマ StackJimmy によって設計されています。