9. {% extends "layout.html" %}
{% block body %}
<ul>
{% for user in users %}
<li><a href="{{ user.url }}">{{ user.username }}</a></li>
{% endfor %}
</ul>
{% endblock %}
10. Sandboxed Execution Mode
Every aspect of the template execution is monitored and explicitly whitelisted or blacklisted,
whatever is preferred. This makes it possible to execute untrusted templates.
Template Inheritance
Makes it possible to use the same or a similar layout for all templates.
Easy to Debug
With a debug system that integrates template compile and runtime errors into the standard Python
traceback system.
Configurable Syntax
For instance you can reconfigure Jinja2 to better fit output formats such as LaTeX or JavaScript.
(skipped the features more relevant to high-volume usage such as in Django)
11.
12. Accepts any text file type
text, xml, html, etc
Convention is to name files with .j2 extension
http.conf.j2, sshd_config.j2
Convention to place in the templates/ directory
templates/http.conf.j2, templates/sshd_config.j2
14. Accessing Ansible variables like
{{ ansible_hostname }} {{ ansible_date_time.epoch }}
We can do math like {{ 1+3 }}
Standard data types, like my list: {{ ('a','b','c') }}
We can call standard methods associated with our types:
{{ "lorem ipsum".upper() }} {{ ['a','b','c'].pop() }}
15. Inline Conditionals: {{ '[%s]' % page.title if page.title }}
Built-in Filters:
{{ my_var | default('my_var undefined') }}
Maths: abs, int, float, round, sum
Str: capitalize, length, center, escape, lower, regex
Lists: join, last, sort, shuffle, json_query
16. Loops:
<ul>
{% for href, caption in my_list }}
<li><a href="{{ href }}">{{ caption }}</a></li>
{% endfor %}
</ul>
Conditionals:
{% if kenny.sick %}
Kenny is sick.
{% elif kenny.dead %}
You killed Kenny! You bastard!!!
{% else %}
Kenny looks okay --- so far
{% endif %}
17. {#
Note: Nothing in the comment will be included
in the template output
{% for user in users %}
...
{% endfor %}
#}
22. Alternation:
{% for row in rows %}
<li class="{{ loop.cycle('odd', 'even') }}">{{ row }}</li>
{% endfor %}
Empty Lists:
<ul>
{% for user in users %}
<li>{{ user.username|e }}</li>
{% else %}
<li><em>no users found</em></li>
{% endfor %}
</ul>
23. Sort by Attribute:
{% for item in iterable|sort(attribute='date') %}
...
{% endfor %}
Group by Attribute:
{% for group in persons|groupby('gender') %}
<li>{{ group.grouper }}<ul>
{% for person in group.list %}
<li>{{ person.first_name }}</li>
{% endfor %}</ul></li>
{% endfor %}