interpolate-json
Interpolate a Javascript Object (json) or string with (another) json - Advanced (or Substitution, as others may like to call it).
Minimalist & lightweight ;) approach to handle interpolation, which packs way more punch than simple string parameter replacement.
Supports:
${string}
interpolation${json}
interpolation${multi.level}
json notation- single
${= JavaScript.expression() =}
evaluation - custom
{{parameter_boundary}}
declaration
Install
npm install interpolate-json
yarn add interpolate-json
Usage
Declaration
const interpolation = require('interpolate-json').interpolation;
const { interpolation } = require('interpolate-json');
import { interpolation } from 'interpolate-json';
string
let someString = 'I want to be ${character} in ${business.type} by being a ${business.post}';
let values = {
character: 'a Hero',
business: {
type: 'saving people',
post: 'Doctor',
},
};
someString = interpolation.expand(someString, values);
console.log(someString);
let someString = "Hi, my name is '${USER_NAME}'. I'm ${USER_AGE}";
console.log(interpolation.expand(someString, process.env));
json
let myJson = {
port: '8080',
server: 'www.example.com',
user: 'abcd',
password: 'P@ss#ord',
url: 'https://${user}:${= encodeURIComponent(${password}) =}@${server}:${port}'
};
console.log(interpolation.expand(myJson));
{
"port": "8080",
"server": "www.example.com",
"user": "abcd",
"password": "P@ss#ord",
"url": "https://abcd:P%40ss%23ord@www.example.com:8080"
}
let myJson = {
port: '${PORT}',
server: 'www.example.com',
user: '${=${USER_NAME}.toLowerCase()=}',
password: '${USER_PASSWORD}',
url: 'https://${user}:${= encodeURIComponent(${password}) =}@${server}:${port}'
};
console.log(interpolation.expand(myJson));
{
"port": "8080",
"server": "www.example.com",
"user": "john",
"password": "P@ss#ord",
"url": "https://john:P%40ss%23ord@www.example.com:8080"
}
Notice that ${= =}
notation. It's a cool way to use JavaScript expression (not expressions, yet, just a single line).
Get the full documentation in WIKI