Highlight.js plugin for Vue.js
This plugin provides a highlightjs
component for use
in your Vue.js applications:
<div id="app">
<highlightjs autodetect :code="code" />
<highlightjs language='javascript' code="var x = 5;" />
</div>
Using the pre-built libraries
<link rel="stylesheet" href="/path/to/styles/default.css">
<script src="/path/to/highlight.min.js"></script>
<script src="/path/to/highlight-vue.min.js"></script>
Then simply register the plugin with Vue:
Vue.use(hljsVuePlugin);
Using ES6 modules / bundling
import hljs from 'highlight.js/lib/core';
import javascript from 'highlight.js/lib/languages/javascript';
import vuePlugin from "@highlightjs/vue-plugin";
hljs.registerLanguage('javascript', javascript);
Vue.use(vuePlugin);
Note: The plugin imports highlight.js/lib/core
internally (but no languages). Thanks to the magic of ES6 modules you can import Highlight.js anywhere to register languages or configure the library. Any import of Highlight.js refers to the same singleton instance of the library, so configuring the library anywhere configures it everywhere.
You can also simply load all "common" languages at once (as of v11):
import hljs from 'highlight.js/lib/common';
import vuePlugin from "@highlightjs/vue-plugin";
Vue.use(vuePlugin);
Building the pre-built library from source
We use rollup to build the dist
distributable.
npm run build