mkdocs-terminal with Highlight.js#

This example site uses the Highlight.js javascript library to add code highlighting to a page after it is loaded in the user's web browser.

Please review the Highlight.js docs for more information:

Set Up#

Add Highlighter Code#

Create a javascript file which will trigger the Highlight.js library to highlight code blocks.

Save the file in your MkDocs docs folder and reference it in the extra_javascript section of mkdocs.yml:

window.addEventListener('load', hljs_highlight, false);

function hljs_highlight() {
    hljs.highlightAll();
}

For this example site the above javascript code is saved to docs/add_hljs_highlight.js.

Add Highlight.js Library#

javascript files#

Add the Highlight.js javascript library file(s) to your mkdocs.yml:

highlight.min.js
Required. the core Highlight.js library logic and highlighting instructions for ~40 common programming languages

add_hljs_highlight.js
Required. a small script which uses the Highlight.js library to hilight code blocks once an HTML page is loaded in the browser (see Add Highlighter Code)

LANGUAGE.min.js
Optional. highlighting instructions for any language not included in the core library

CSS files#

Terminal for MkDocs comes with built-in CSS styling for Highlight.js. This means that you don't have to specify an external stylesheet for code hilighting when you use Highlight.js.

If you prefer one of the community Highlight.js style options you can specify it in the extra_css attribute in mkdocs.yml:

extra_css:
  - https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.11.0/styles/a11y-light.min.css

mkdocs.yml example#

The following excerpt is used to configure code hilighting on this example site:

theme:
  name: terminal

extra_javascript:
  - https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.11.0/highlight.min.js
  - https://unpkg.com/highlightjs-cobol/dist/cobol.min.js
  - add_hljs_highlight.js

extra_css:
  - https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.11.0/styles/a11y-light.min.css