This is the 19th day of my participation in the Gwen Challenge in November. Check out the details: The last Gwen Challenge in 2021
A useful formula plug-in for Hexo is Mathjax. However, due to swig’s file parsing mechanism, multi-line formulas cannot be displayed properly in Hexo. This article describes a solution to this problem.
Introduction to the
I believe that many academic research dogs have heard how beautiful papers written in LaTeX are. LaTeX is simply a word processor/computer markup language. As a primer, this article does not attempt to explain too much about the ethical relationships among its family of TeX, LaTeX, CTeX, and so on. On the one hand, as anyone who has used Word knows, typesetting can sometimes take longer than writing an article. There are even some unsolvable metaphysical problems; On the other hand, for many top journals and conferences, the submission format of papers is explicitly required to be LaTeX, and Word format is rejected
LaTeX, as a generalized computer markup language (such as HTML), inherits the proud tradition of computer languages and is unambiguous by expressing precise meanings in simple code. The results of the article typesetting can be completely in accordance with your ideas, not only to solve the metaphysical problems, rendering out the beautiful article; It can also write elegant mathematical formulas with simple syntax, and Markdown already supports LaTeX formulas
But the default formula rendering tool in Hexo isn’t perfect, and there are always strange problems
Problem of repetition
- Ready to enter a matrix:
{% raw %}
{% endraw %}
- Enter a multi-line formula
{% raw %}
{% endraw %}
Question 1
- At this time to run
hexo g
或hexo s
Error may be reported:
Unhandled rejection Nunjucks Error: [Line 11, Column 65] expected variable end
===== Context Dump =====
=== (line number probably different from source) ===
Copy the code
Question 2
- Or if the formula is not normal, multiple lines of formula will be squeezed into one line:
Cause analysis,
Question 1
- Because hexo decoding focuses on sequential characters such as {% raw %}{{,}}, %% {% endRAW %}, this part of the code will be interpreted as something else with special meaning
- If such a character happens to be present in the formula, the above error is reported
Question 2
- Because hexo is in the formula
\ \
The error would be an escape, meaning that he would only see a backslash and not execute a newline command, resulting in a stack of formulas
The solution
Switch compiler
- Instead of MathJax, use Katex
This problem is due to some character conflicts between the template rendering engine and Mathjax, and the Katex rendering formula can be used instead. Katex is a lightweight and fast formula typesetting library. You don’t have to worry too much about the display; after all, it’s something people use all over the world.
Katex does not work well in individual tests and is not recommended
A temporary solution
For question 1
- Can be in continuous
{
}
%
Insert a space in the middle and you’ll be fine
For question 2
- Can be
\ \
Switch to\ \ \ \
, can realize the formula of multiple lines correct display
The ultimate solution
-
It was mentioned in the official documentation that we could provide a tag for Hexo to prevent it from interpreting our string according to its own rules and displaying its original meaning
-
Marked as
{% raw %} ... {% endraw %} Copy the code