Note: This documentation is for Moodle 2.7. For up-to-date documentation see Chemistry notation using mhchem.

Chemistry notation using mhchem

From MoodleDocs

Note: This page is a work-in-progress. Feedback and suggested improvements are welcome. Please join the discussion on or use the page comments.

The mhchem pack­age pro­vides com­mands for type­set­ting chem­i­cal molec­u­lar for­mu­lae and equa­tions.

Why mhchem?

It is possible to display chemical formulae and equations using TeX mathematics mode. However, it is rather cumbersome for a range or reasons. Different display conventions: uppercase letters are displayed in italics for mathematics, whereas element symbols are upright for chemistry. The complexities of supercript and subscript notation, ions and isotopes. Bonds, equilibrium reaction arrows etc.

The mhchem extension allows a more adaptable display and more natural input of chemical formulae and equations. In Moodle, mhchem syntax can use text input directly into an HTML editor (TinyMCE or Atto) or by an Atto chemistry plugin (similar to the equation plugin).

This is particularly useful for documenting isotopes, relative atomic and relative molecular mass, empirical and molecular formulae, balanced equations (full and ionic), equilibium reactions and themodynamics.

For more complex structural and displayed formulae (e.g. organic chemistry), homologous series and functional groups, you may also wish to consider a 'drawing' plugin such as the MarvinJS-based Chemical structures and reaction editor


The mhchem package can be integrated with Moodle in one of two ways, though the first (via MathJax) is recommended.

via MathJax

The recommended way is by using MathJax to render TeX notation and include the mhchem extension. MathJax has become the de facto standard for displaying mathematics on the Web and since version 2.7 Moodle has a MathJax loader filter enabled by default. However, mhchem needs to be added to the MathJax configuration.

In Administration > Site administration > Plugins > Filters > Mathjax > Local Mathjax installation, edit the Mathjax configuration to include mhchem.js in the TeX extensions:

TeX: {extensions: ["mhchem.js","color.js","AMSmath.js","AMSsymbols.js","noErrors.js","noUndefined.js"]},

via LaTeX

It is also possible to add the mhchem bundle alongside LaTex on the Moodle server, and then use theTeX filter. However, this may be tricky and display issues can be difficult to debug. If you do wish to pursue the TeX filter option, installation details will depend on the server operating system. Some Linux distributions can use their standard package manager to install mhchem and dependencies. For Fedora 20, this is simply:

yum install texlive-mhchem

Once installed, in your Moodle Administration > Site administration > Plugins > Filters > TeX notation > LaTeX renderer Settings, add the following to the LaTeX preamble:


The following gives a filled arrowhead style, which may be preferred.



Note that mhchem is not currently installed in this documentation wiki. Therefore the chemical display of chemical formulae and equations is simulated and may not exactly correspond to rendering using mhchem, which is usually nicer!.

The default TeX delimiters are \[...\] or $$...$$ for displayed mathematics, and \(...\) for in-line mathematics. For mhchem the additional delimiter \ce{...} is required inside the mathematics delimeters i.e .\[\ce{...}\] or $$\ce{...}$$ for displayed chemical formulae, and \(\ce{...}\) for in-line chemical formulae. In the rest of this document the TeX delimiters are not explicitly shown.












Place amounts directly in front of a formula. A small space will be inserted automatically.






When you are in a math environment (e.g. opened and closed with a \[...\], \(...)\ or $$...$$), you could simply use \ce to set content in an upright font. Remember: all variables—like V for volume—are set using an italic font, physical units and chemical elements are set using an upright font.


When used in text mode, \ce adapts to the current text font. You could simply write a formula in one of your section titles it would be set with the correct, no matter where is appears (sectiontitle, header, contents, references, ...).

, \ce{H2O}, $\ce{H2O}$


There are some special cases. A negative charge (-) in text mode is replaced with a dash (–), because a text minus sign often is too short. All ‘operators’, e.g. ‘+’ and reaction arrows, are always taken from the math font.

Special Symbols




, $\ce{RNO2^{-.}}$, \ce{RNO2^{-.}}



Horizontal bonds can be set using the characters -, = and # (single, double, triple bond) inside a formula (a - at the end of a formula yields a negative charge).



\ce{A\sbond B\dbond C\tbond D}

Different books visualise bonds in extremely different ways. Currently, the minus sign from the math font is used to display the bonds (even in text mode). The bonds are vertically aligned on the math axis. For most math fonts, this is lower than half the height of a capital letter.

The \bond command allows you to typeset some types of special bonds.






Using Math

To use math commands inside \ce{...}, one can enclose the commands with $.


\ce{$x\,$ Na(NH4)HPO4 ->[\Delta](NaPO3)_{$x$} + $x\,$ NH3 ^ + $x\,$ H2O}


Reaction Arrows

\ce{CO2 + C -> 2CO}

\ce{CO2 + C <- 2CO}

\ce{CO2 + C <=> 2CO}

\ce{H+ + OH- <=>> H2O}

\ce{$A$ <-> $A’$}

\ce{CO2 + C ->[\alpha] 2CO}

\ce{CO2 + C ->[\alpha][\beta] 2CO}

As with ^ and _, the content above and below reaction arrows is set in math font. When you want to put descriptive text there, use the \text command. Or, as a shortcut, you could type a ‘T’ between reaction arrow and opening bracket.

\ce{CO2 + C ->[\text{above}] 2CO}

\ce{CO2 + C ->[\text{above}][\text{below}] 2CO}

\ce{CO2 + C ->T[above][below] 2CO}

Similarly, there is a shortcut for using \ce with reaction arrows:

\ce{$A$ ->[\ce{+H2O}] $B$}

\ce{$A$ ->C[+H2O] $B$}

Precipitate and Gas

Use v or (v) for precipitate (arrow down) and ^ or (^) for gas (arrow up), both separated by spaces.

\ce{SO4^2- + Ba^2+ -> BaSO4 v}

Watch Out!

Please be aware that you sometimes have to enclose spaces in braces. In particular, you have to do so, when they appear between brackets that belong to an reaction arrow.

\ce{$A$ <->T[{Enclose spaces!}] $A’$}

Further Examples

\ce{Zn^2+ <=>[\ce{+ 2OH-}][\ce{+ 2H+}]$\underset{\text{amphoteric hydroxide}}{\ce{Zn(OH)2 v}}$<=>C[+2OH-][{+ 2H+}]$\underset{\text{tetrahydroxozincate}}{\cf{[Zn(OH)4]^2-}}$}

$K = \frac{[\ce{Hg^2+}][\ce{Hg}]}{[\ce{Hg2^2+}]}$

\ce{Hg^2+ ->[\ce{I-}]$\underset{\mathrm{red}}{\ce{HgI2}}$->C[I-]$\underset{\mathrm{red}}{\ce{[Hg^{II}I4]^2-}}$}

Further information

The mhchem package

mhchem manual

MathJax and mhchem