pupo
📦 NODE.JS - Simple micro templating based on pupa using object-path.
Useful when all you need is to fill in some placeholders.
Pupo implements the object-path package to resolve the values of the data object.
Install
$ npm install pupo
# or
$ yarn add pupo
Usage
const pupo = require("pupo");
pupo("The mobile number of {name} is {phone.mobile}", {
name: "Foo",
phone: {
mobile: "100 20 300",
},
});
pupo("I like {0} and {1}", ["🦄", "🐮"]);
pupo("I like {{0}} and {{1}}", ["<br>🦄</br>", "<i>🐮</i>"]);
pupo("{deep.obj.value-foo}", {
deep: {
obj: {
"value-foo": "Hello, World!",
},
},
});
pupo("{foo bar} {12 345} {value-foo}", {
"foo bar": "Foo Bar",
"12 345": "12345",
"value-foo": "Hello, World!",
});
API
pupo(template, data)
template
Type: string
Text with placeholders for data
properties.
data
Type: object | unknown[]
Data to interpolate into template
.
FAQ
What about template literals?
Template literals expand on creation. This module expands the template on execution, which can be useful if either or both template and data are lazily created or user-supplied.
Related
- pupa - The original package.