Runtime Template Compiler
Vue.js component for easy compiling and interpreting of HTML templates at runtime.
A
An interactive demo of the compiler can be found over at CodeSandbox
This is a simple library that makes use of the vue-template-compiler
to generate a component on the fly from a HTML string, which solves the template binding issues that you get with the v-html
directive.
The Vue Runtime Template Compiler
makes it easy to get a template string either from a local variable or from a remote source, and then compile and render it as a component using scope of the parent.
You do not need to use the use the with-compiler
version of Vue.js, as this bundles the vue-template-compiler
. This is handy as you might not want to use the runtime compiler in the whole application. Using Webpack and code splitting you can ensure that the compiler is only fetched when necessary.
Keep in mind that the template can only access the instance properties of the component that is using it.
Installation
Direct Download / CDN
https://unpkg.com/vue-runtime-template-compiler/dist/vue-runtime-template-compiler.umd.js
Unpkg.com provides npm-based CDN links. The above link will always point to the latest release on npm. You can also use a specific version/tag via URLs like https://unpkg.com/vue-runtime-template-compiler@1.1.0/dist/vue-runtime-template-compiler.umd.js
.
Include Vue Runtime Template Compiler
after Vue.js and it will install itself automatically:
NPM
$ npm i vue-runtime-template-compiler
Yarn
$ yarn add vue-runtime-template-compiler
When used with a module system, you must explicitly install the compiler via Vue.use()
:
Vue
Getting Started
To use the Vue Runtime Template Compiler
plugin you just need to import the runtime-template-compiler
component and pass in the template that you want to use. You may either use it as a plugin, or you can use the component directly. Either way you decide to install it the usage of the component will be the same.
Note: When using Webpack you can use code splitting so that you do not load the runtime compiler in to your whole application.
Using the plugin
If you have installed the plugin using the Vue.use()
method then you can use the component like this:
Using the component
Or if you choose to you can load the component directly.
Parent Context
The template you pass has access to the parent component scope. You can access computed properties and methods as well from the template.
However if you have wrapped the runtime-template-compiler
in another component it may be necessary to set the parent property on the compiler component, else you might end up with the wrong scope being bound.
Methods
As with the data
object the methods
are also available in the runtime-template-compiler
. You just use them as if you are writing bindings in the parent's compiled template.
Note: These will behave as if they have been called from within the parent component.
Computed
Just like the methods
the computed
properties are available in the runtime-template-compiler
. The same as the other parent property you use them as if you are writing bindings in the parent's compiled template.
Props
Just like the computed
the props
properties are available in the runtime-template-compiler
. The same as the other parent property you use them as if you are writing bindings in the parent's compiled template.
Filters
Just like the props
the filters
are available in the runtime-template-compiler
. The same as the other parent property you use them as if you are writing bindings in the parent's compiled template.
Filters
Just like the props
the provide
properties are available in the runtime-template-compiler
. The same as the other parent property you use them as if you are writing bindings in the parent's compiled template.
Tests
To run the test suite, first install the dependencies, then run npm test
:
$ npm install$ npm test
Documentation
To check out live examples and docs, visit https://jonwatkins.github.io/vue-runtime-template-compiler/
Browser Compatibility
Vue.js supports all browsers that are ES5-compliant (IE8 and below are not supported).
Changelog
Detailed changes for each release are documented in the release notes.
License
Copyright (c) 2020-present Jon Watkins