Skip to content

sumbad/template-literals-loader

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Template literals loader

The template-literals-loader is a module for webpack to use Template literals as HTML template from a separate file.

This plugin adds a wrapper to a template file and returns it as a function.

Installation

npm install template-literals-loader -D

Usage

If you want to use this module with new browsers you can just setting webpack.

webpack.config.js

...
{
    test: /\.html?$/,
    loader: "template-literals-loader"
},
...

Examples

template.html

<h1>Hello, ${name}</h1>

main.js with tagged template literals

const template = require('./template.html');

function myTagFunc(chunks, ...interpolations) {
  console.log(chunks);
  console.log(interpolations);
}

const config = { 
  scope: {name: 'world'}, // optional
  tag: myTagFunc          // optional
};

template(config);

The result:

// ["<h1>Hello, ", "</h1>", raw: ["<h1>Hello, ", "</h1>"]]
// ["world"]

main.js without tagged template literals

const template = require('./template.html');

const config = { 
  scope: {name: 'world'}, 
};
console.log(template(config));

The result:

// <h1>Hello, world</h1>

You can set a config or not. If you don't use the config.scope it will use current [[Scope]]. I.e. in a tepmplate you will have to write <h1>Hello, ${this.name}</h1> and set the name variable in your code.

Usage with a class:

template.html

<h1>Hello, ${this.name}</h1>

main.js

const template = require('./template.html');

class Hello {
  name = 'Den!';
  _template;

  constructor() {
    this._template = template;

    console.log(this._template()); //<h1>Hello, Den!</h1>
  }
}

About

Webpack loader for Template literals

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published