Highlight your plaintext in any container via Shiki.
By using the CSS Custom Highlight API, code can be highlighted on plain text nodes without rich text. It will help you get the lightest code editor.
pnpm i plain-shiki-
Firstly, create any element that can contain text nodes, e.g.
<div class="plain-shiki"></div> -
Add the
contenteditableattribute to this element. If you don't mind the compatibility of the target browser, you can specify its value asplaintext-only -
Write the following code:
import { createPlainShiki } from "plain-shiki";
import { createHighlighterCore } from "shiki/core";
import { createJavaScriptRegexEngine } from "shiki/engine-javascript.mjs";
import grammarTs from "shiki/langs/typescript.mjs";
import vitesseDark from "shiki/themes/vitesse-dark.mjs";
import vitesseLight from "shiki/themes/vitesse-light.mjs";
const shiki = await createHighlighterCore({
langs: [grammarTs],
themes: [vitesseLight, vitesseDark],
engine: createJavaScriptRegexEngine(),
});
const el = document.querySelector(".plain-shiki") as HTMLElement;
createPlainShiki(shiki).mount(el, {
lang: "ts",
themes: {
light: "vitesse-light",
dark: "vitesse-dark",
},
});