Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
micromustache
Advanced tools
A faster and smaller subimplementation of the {{mustache}} template engine for JavaScript
This small library covers the most important use case for Mustache templates: interpolation: replacing variable names with their values from an object.
If that's all you need, micromustache is a drop-in replacement for MustacheJS.
Micromustache achieves faster speed and smaller size by dropping the following features from MustacheJS:
arrName.1
though)If you can live with this, read on...
render(template, view = {}, customResolver)
template: string
: The template containing one or more {{variableNames}}
.view: Object
: An optional object containing values for every variable names that is used in the
template. If it's omitted, it'll be assumed an empty object.customResolver: function (varName, view)
An optional function that will be called for every
{{varName}}
to generate a value. If the resolver throws we'll proceed with the default value
resolution algorithm (find the value from the view object).The return is always the same type as the template itself (if template is not a string, it'll be
returned untouched and no processing is done). All {{varName}}
strings inside the template will
be resolved with their corresponding value from the view
object.
If a particular path doesn't exist in the view
object, it'll be replaced with empty string (''
).
Objects will be JSON.stringified()
but if there was an error doing so (for example when there's
a loop in the object, they'll be simply replaced with {...}
.
var person = {
first: 'Michael',
last: 'Jackson'
};
micromustache.render('Search for {{first}} {{ last }} songs!', person);
// output = "Search Michael Jackson popcorn!"
// If a custom resolver was provided it would be called two times with these params:
// ('first', person)
// ('last', person) <-- notice the varName is trimmed
You can even access array elements and length
because they are all valid keys in the array object
in javascript:
var fruits = [ 'orange', 'apple', 'lemon' ];
micromustache.render('I like {{0}}, {{1}} and {{2}} ({{length}} fruits!)', fruits);
// output = "I like orange, apple and lemon (3 fruits!)"
// If a custom resolver was provided it would be called three times with these params:
// ('0', person) <-- notice that the array indices are sent as strings.
// ('1', person)
// ('2', person)
Note: if a key is missing or null
, it'll be treated as if it contained a value
of empty string (i.e. the {{variableName}} will be removed from the template).
var person = {
first: 'Michael',
last: 'Jackson'
};
micromustache.render('He was {{age}} years old!', person);
// output = "He was years old!"
You can easily reference deep object hierarchies:
var singer = {
first: 'Michael',
last: 'Jackson',
children: [
{
first: 'Paris-Michael',
middle: 'Katherine',
},
{
first: 'Prince',
middle: 'Michael',
prefix: 'II'
},
{
first: 'Michael',
middle: 'Joseph',
prefix: 'Jr.'
}
]
}
micromustache.render("{{first}} {{last}} had {{children.length}} children: {{children.0.first}}, {{children.1.first}} and {{children.2.first}}", singer);
//output = "Michael Jackson had 3 children: Paris-Michael, Prince and Michael"
As you can see unline MustacheJS, micromustache doesn't have loops.
view
is null
or
undefined
, MustacheJS throws an exception but micromustache doesn't. It just assumes an empty
object for the view.customResolver
doesn't exist in MustacheJS but is a powerful little utility that halps
some use cases.compile(template, customResolver)
This is a utility function that accepts a template
and customResolver
and returns a renderer
function that only accepts view and spits out filled template. This is useful when you find yourself
using the render function over and over again with the same template. Under the hood it's just a thin
layer on top of render
so it uses the same parameters 👆.
A function that accepts a view
object and returns a rendered template string.
const templateEngine = micromustache.compile('Search {{first}} {{ last }} popcorn!');
var output = templateEngine(person);
// output = "Search Michael Jackson popcorn!"
output = templateEngine({first:'Albert',last:'Einstein'});
// output = "Search Albert Einstein popcorn!"
compile()
doesn't do any memoization so it doesn't introduce any performance improvmenet to your
code.
Micromustache comes with a simple CLI that brings the render()
functionality to shell programming.
npm i -g micromustache
This will make the micromustache
command available on your shell.
It works like this:
micromustache templatePath viewPath
Both parameters are required.
templatePath
: path to a template text file that contains {{varName}} in itviewPath
: path to a valid json fileFiles are read/write with utf8 encoding.
By default CLI prints the output to console (and erros to stderr).
You can redirect it to output file using > outputPath
.
micromustache template.txt view.json > output.txt
This command reads the contents of template.txt
and render()
it using data from view.json
and puts the result text in output.txt
.
We use Mocha/Chai for tests. If you want to run the tests, install dependencies and run them using npm:
npm it
Q. What about ES6 template literals (AKA "template strings")? Aren't they gonna deprecate this library?
A. The expressions in a string literal can't reference values from outside its scope. Therefore it is not possible to simply pass an object and resolve variables from its keys. The tagged template literals cover part of the functionality but they:
However, since when they are natively supported by the runtime, they have a great performance and if you learn to use the native way of doing things, you don't have to learn an ever-changing library, though their functionality is more limited than MustacheJS.
FAQs
A fast, minimal and secure template engine for JavaScript
The npm package micromustache receives a total of 29,789 weekly downloads. As such, micromustache popularity was classified as popular.
We found that micromustache demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.