3.3 模板中的控制结构

————————————————————————前言———————————————————————————

就像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>




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值