marked-highlight
Highlight code blocks
Usage
You will need to provide a function that transforms the code
to html.
import {Marked} from "marked";
import {markedHighlight} from "marked-highlight";
import hljs from 'highlight.js';
const marked = new Marked(
markedHighlight({
langPrefix: 'hljs language-',
highlight(code, lang) {
const language = hljs.getLanguage(lang) ? lang : 'plaintext';
return hljs.highlight(code, { language }).value;
}
})
);
marked.parse(`
\`\`\`javascript
const highlight = "code";
\`\`\`
`);
The async
option should be set to true
if the highlight
function returns a Promise
.
import {Marked} from "marked";
import {markedHighlight} from "marked-highlight";
import pygmentize from 'pygmentize-bundled';
const marked = new Marked(
markedHighlight({
async: true,
highlight(code, lang) {
return new Promise((resolve, reject) => {
pygmentize({ lang, format: 'html' }, code, function (err, result) {
if (err) {
resolve(err);
return;
}
resolve(result.toString());
});
});
}
})
)
marked.parse(`
\`\`\`javascript
const highlight = "code";
\`\`\`
`);
options
option | type | default | description |
---|
async | boolean | false | If the highlight function returns a promise set this to true . Don't forget to await the call to marked.parse |
langPrefix | string | 'language-' | A prefix to add to the class of the code tag. |
highlight | function | (code: string, lang: string) => {} | Required. The function to transform the code to html. |