————————————————————————前言———————————————————————————
就像python语言中有if for 函数等控制结构, 模板中也有类似的控制结构, 本节我们来介绍4种控制结构。
——————————————————————————————————————————————————————
一. 条件控制语句
{% if user %}
Hello, {{ user }}!
{% else %}
Hello, Stranger!
{% endif %}
二. for循环语句
<ul>
{% for comment in comments %}
<li>{{ comment }}</li>
{% endfor %}
</ul>
三. 宏
{% macro render_comment(comment) %}
<li>{{ comment }}</li>
{% endmacro %}
<ul>
{% for comment in comments %}
{{ render_comment(comment) }}
{% endfor %}
</ul>
为了重复使用宏, 我们可以将其保存在单独的文件中(macros.html), 然后在需要使用的模板中导入:
{% import 'macros.html' as macros%}
<ul>
{% for comment in comments%}
{{ macros.render_comment(comment) }}
{% endfor %}
</ul>
四.模板继承
需要在多处重复使用的模板代码片段可以写入单独的文件, 再包含在所有模块中, 以避免重复:
{% include 'commen.html' %}
另一种重复使用代码的强大方式是模板继承, 类似于python中的类继承。
首先, 创建一个名为base.html的奇模板:
<html>
<head>
{% block head %}
<title>{% block title%}{% endblock %} - My Application</title>
{% endblock %}
</head>
<body>
{% block body%}{% endblock %}
</body>
</html>
block标签定义的元素可在衍生模板中修改, 以下示例是衍生模板:
{% extends 'base.html' %}
{% block title %}Index{% endblock %}
{% block head %}
{{ super() }}
<style>
</style>
{% endblock %}
{% block body %}
<h1>Hello, World!</h1>
{% endblock %}
在extends指令之后, 基模板中的3个块被重新定义, 模板引擎会将其插入适当的位置。
注意新定义的head块, 在基模板中内容不是空的, 所以用super语句获取原来的内容。
所以衍生模板的内容就相当于:
<html>
<head>
<title>Index - My Application</title>
<style> </style>
</head>
<body>
<h1>Hello, World!</h1>
</body>
</html>