Plate is a Django Template Language implementation in Javascript. Super exciting!
Yes. Plate was designed to work well in the standard suite of browsers. Each minor point release will target compatibility with IE7+, FF3+, Chrome, and Safari 4+.
You can download a minified, precompiled version here.
If you're having trouble, try using the debug version, with source maps.
var plate = require('plate')
var template = new plate.Template('hello {{ world }}')
template.render({world:'everyone'}, function(err, data) {
console.log(data)
})
// outputs "hello everyone"
Plate follows the Node.js style of taking callbacks that receive an error object and a data object. If there's no
error, err will be null.
<script type="text/javascript" src="plate.min.js">
<script type="text/html" id="template">
hello {{ world }}.
</script>
<script type="text/javascript">
var source = $('#template').text()
, template = new plate.Template(source)
template.render({world: 'everyone'}, function(err, data) {
console.log(data)
})
</script>
require(['plate.min'], function(plate) {
var template = new plate.Template('hello {{ world }}')
})
Plate is documented on its github wiki. There are "Getting Started" guides for both in-browser as well as in-node environments.
Got a feature you'd like to add? I'd love to see it. The workflow is pretty standard Github fare:
The minimum requirements for a pull request to be merged are:
docs/ folder in Markdown format.In node:
$ npm install plate
$ npm test plate
Licensed MIT.