django-templatetag-handlebars allows you to embed Handlebars.js templates in your django templates.
Most of the template tag code comes from Miguel Araujo's verbatim snippet.
pip install django-templatetag-handlebars
- Add
templatetag_handlebars
to yourINSTALLED_APPS
- Add the HTML header :
{% load templatetag_handlebars %} <head> {% handlebars_js %} ... </head>
- Call the template tag, and write your Handlebars template :
{% tplhandlebars "tpl-infos" %} {{total}} {% trans "result(s)." %} <p>{% trans "Min" %}: {{min}}</p> <p>{% trans "Max" %}: {{max}}</p> {% endtplhandlebars %}
- The following block with end-up in your page :
<script id="tpl-infos" type="text/x-handlebars-template"> {{total}} result(s). <p>Min: {{min}}</p> <p>Max: {{max}}</p> <script>
- Render it, client-side, as usual using
Handlebars.js
API :
var properties = { total: 10, min: 4, max: 5 }; var template = Handlebars.compile($('#tpl-infos').html()), rendered = template(properties);
- Your rendered string is ready, and waiting to be inserted in your DOM :)
10 result(s). <p>Min: 4</p> <p>Max: 5</p>
A {% verbatim %} tag is available to escape a specific part. For example, you may want a subpart of your Handlebars template to be rendered by Django :
<script id="tpl-django-form" type="text/x-handlebars-template"> <form> {% verbatim %} {{#if id}}<h1>{{ id }}</h1>{{/if}} {% endverbatim %} {{ yourform.as_p }} </form> </script>
- Mathieu Leplatre <[email protected]>
- Miguel Araujo <https://github.com/maraujop>
- django-handlebars by Sergii Iavorskyi, which focuses on server-side Handlebars rendering.
- django-handlebars by Chris Vigelius, with templates in separate files, and served in one block.
- Lesser GNU Public License
Handlebars.js
is released under the MIT license - Copyright 2011 Yehuda Katz