marked-html-renderer
v1.1.0
Published
marked HTML renderer
Maintainers
Readme
marked-html-renderer
Marked extension to renderer html elements instead of a string.
Usage
import {Marked} from "marked";
import markedHtmlRenderer from "marked-html-renderer";
// or UMD script
// <script src="https://cdn.jsdelivr.net/npm/marked/lib/marked.umd.js"></script>
// <script src="https://cdn.jsdelivr.net/npm/marked-html-renderer/lib/index.umd.js"></script>
const marked = new Marked();
marked.use(markedHtmlRenderer());
const htmlElements = marked.parse("# example html"); // returns a DocumentFragment
document.body.append(htmlElements);For typescript use Marked<DocumentFragment, Node | string> to tell marked that it should return a DocumentFragment instead of a string.
import {Marked} from "marked";
import markedHtmlRenderer from "marked-html-renderer";
const marked = new Marked<DocumentFragment, Node | string>();
marked.use(markedHtmlRenderer());
const htmlElements: DocumentFragment = marked.parse('# example html', { async: false });
document.body.append(htmlElements);You can also pass an alternate provider for document, eg. JSDOM for use in a server-side context.
import {Marked} from "marked";
import markedHtmlRenderer from "marked-html-renderer";
import { JSDOM } from "jsdom";
const marked = new Marked();
marked.use(markedHtmlRenderer({ document: new JSDOM('').window.document }));
// DocumentFragment.childNodes contains Elements, where the string representation is childNode.outerHTML
const htmlElements = marked.parse('# example html');