Highlight.js — это инструмент для подсветки синтаксиса, написанный на JavaScript. Он работает и в браузере, и на сервере. Он работает с практически любой HTML разметкой, не зависит от каких-либо фреймворков и умеет автоматически определять язык.
Минимум, что нужно сделать для использования highlight.js на веб-странице — это
подключить библиотеку, CSS-стили и вызывать initHighlightingOnLoad
:
<link rel="stylesheet" href="/path/to/styles/default.css">
<script src="/path/to/highlight.min.js"></script>
<script>hljs.highlightAll();</script>
Библиотека найдёт и раскрасит код внутри тегов <pre><code>
, попытавшись
автоматически определить язык. Когда автоопределение не срабатывает, можно явно
указать язык в атрибуте class:
<pre><code class="html">...</code></pre>
Список поддерживаемых классов языков доступен в справочнике по классам.
Класс также можно предварить префиксами language-
или lang-
.
Чтобы отключить подсветку для какого-то блока, используйте класс nohighlight
:
<pre><code class="nohighlight">...</code></pre>
Чтобы иметь чуть больше контроля за инициализацией подсветки, вы можете
использовать функции highlightBlock
и configure
. Таким образом
можно управлять тем, что и когда подсвечивать.
Вот пример инициализации, эквивалентной вызову initHighlightingOnLoad
, но
с использованием document.addEventListener
:
document.addEventListener('DOMContentLoaded', (event) => {
document.querySelectorAll('pre code').forEach((block) => {
hljs.highlightBlock(block);
});
});
Вы можете использовать любые теги разметки вместо <pre><code>
. Если
используете контейнер, не сохраняющий переводы строк, вам нужно сказать
highlight.js использовать для них тег <br>
:
hljs.configure({useBR: true});
document.querySelectorAll('div.code').forEach((block) => {
hljs.highlightBlock(block);
});
Другие опции можно найти в документации функции configure
.
Подсветку можно запустить внутри web worker'а, чтобы окно браузера не подтормаживало при работе с большими кусками кода.
В основном скрипте:
addEventListener('load', () => {
const code = document.querySelector('#code');
const worker = new Worker('worker.js');
worker.onmessage = (event) => { code.innerHTML = event.data; }
worker.postMessage(code.textContent);
});
В worker.js:
onmessage = (event) => {
importScripts('<path>/highlight.min.js');
const result = self.hljs.highlightAuto(event.data);
postMessage(result.value);
};
Highlight.js можно использовать в браузере прямо с CDN хостинга или скачать индивидуальную сборку, а также установив модуль на сервере. На странице загрузки подробно описаны все варианты.
Не подключайте GitHub напрямую. Библиотека не предназначена для использования в виде исходного кода, а требует отдельной сборки. Если вам не подходит ни один из готовых вариантов, читайте документацию по сборке.
Файл на CDN содержит не все языки. Иначе он будет слишком большого размера. Если нужного вам языка нет в категории "Common", можно дообавить его вручную:
<script charset="UTF-8"
src="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/10.6.0/languages/go.min.js"></script>
Про Almond. Нужно задать имя модуля в оптимизаторе, например:
r.js -o name=hljs paths.hljs=/path/to/highlight out=highlight.js
Highlight.js распространяется под лицензией BSD. Подробнее читайте файл LICENSE.
Официальный сайт билиотеки расположен по адресу https://highlightjs.org/.
Более подробная документация по API и другим темам расположена на http://highlightjs.readthedocs.io/.
Авторы и контрибьюторы перечислены в файле AUTHORS.txt file.