ak-template
Micro-template engine.
Using John Resig's micro-template specs.
API
template(str)
description
Returns compiled template.
N.B: templates are cached.
arguments
String representing the template.
Using John Resig's micro-template format.
return
function (locals) {}
You can pass an Object
as a parameter, it will be accessible within the template through the variable locals
.
See example for more details.
template.globals
Object
Define globals: keys are defaulted with locals.
Think of it more as global defaults. Useful for sharing helper functions.
See example for more details.
template.escape(str)
Escape function, replaces <
, >
, &
, "
, '
by their equivalent HTML entity.
Can be overridden.
Example
var template = require('ak-template');
template.globals.title = 'JavaScript FTW!';
template.globals.upper = function (str) {
return (str + '').toUpperCase();
};
template('<h1><%- locals.title %></h1>')
template('<h1><%- locals.title %></h1>')();
template('<h1><%- locals.title %></h1>')({'title': 'JavaScript is awesome!'});
template('<h1><%- locals.upper(locals.title) %></h1>')({'title': 'JavaScript is awesome!'});
template('<% if (locals.foo) { %><h1>Foo</h1><% } else { %><h2>Bar</h2><% } %>')({'foo': true});
template('<% if (locals.foo) { %><h1>Foo</h1><% } else { %><h2>Bar</h2><% } %>')();
template('<%- locals.word %>')({'word': '<script>do_evil()</script>'});
template('<%= locals.word %>')({'word': '<script>do_evil()</script>'});
template.escape = function (str) {
return str.toUpperCase();
};
template('<%- locals.word %>')({'word': '<script>do_evil()</script>'});
template('<%= locals.word %>')({'word': '<script>do_evil()</script>'});
Why locals
and not using with
?
with
is evil.