Jinja2语法

本文介绍了Jinja2模板引擎的使用,包括模板渲染、变量解析、过滤器应用、流程控制、文件包含、宏定义与调用以及模板继承。通过示例详细讲解了如何在模板中设置变量、应用过滤器、包含文件、定义和调用宏,以及如何实现模板的继承以减少重复代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  • 目录结构

        project/        # 工程目录
        manage.py       # 启动控制文件
        templates/      # 模板文件目录
  • 模板渲染

    • templates目录下创建一个模板文件index.html,在其中写入页面内容

    • 在视图函数中渲染模板:render_template('index.html')

    • 渲染模板字符串:render_template_string('<h1>渲染模板字符串</h1>')

    • 设置模板文件自动加载:app.config['TEMPLATES_AUTO_RELOAD'] = True,调试模式会自动加载

  • 使用变量

    • 需要解析的变量需要放在{{ }}

    • 渲染模板文件时需要传递相关变量:render_template('var.html', name='goudan')

    • 注释写在{# #}

  • 使用过滤器

    过滤器说明
    upper全大写
    lower全小写
    title每个单词首字母大写
    capitalize首字母大写
    trim去掉两边的空白
    striptags过滤HTML标签
    safe渲染时不转义(默认全部转义),只能使用在信任的变量渲染
    • 说明:过滤器就是对要解析的变量进行特定的处理,然后再输出。

    • 使用:{{ 变量|过滤器 }},如:{{ name|upper }},就是将name转换为全大写输出

    • 常用过滤器:

    • 动态开启关闭渲染转义  

{# 动态开启关闭转义 #}
{% autoescape False %}
<div>{{ user }}</div>
{% endautoescape %}
  • 流程控制

  • {% if name %}
        <h1>Hello {{ name }}!</h1>
    {% else %}
        <h1>Hello World!</h1>
    {% endif %}
    ​
    <ol>
        {% for i in range(5) %}
            <li>{{ i }}</li>
        {% endfor %}
    </ol>

     

  • 文件包含

    • 说明:

      当有多处相同的显示效果出现时,将内容单独提取出来,需要的地方直接包含进来即可。包含另一个文件,相当将其中的内容直接粘贴过来,避免了大量重复书写(复制粘贴)

    • 使用:{% include 'include2.html' %}

  • 宏的使用

    • 定义宏:{% macro 宏名(参数) %}宏内容{% endmacro %}

    • 调用宏:{{ 宏名(参数) }}

    • 导入宏:{% from '宏所在文件' import 宏名 %}

    • 说明:宏采用了类似于python中的函数进行定义和调用,可以减少代码的重复书写,而且比较灵活。

  • 模板继承

    • 说明:当一个网站的多个页面都很相似,只要细微的差别,可以通过模板继承减少重复书写。

  • 使用:
  •  parents.html
<html>
<head>
    <meta charset="UTF-8">
    <title>{% block title %}基础模板标题{% endblock %}</title>
</head>
<body>
    {% block body %}<div>默认内容</div>{% endblock %}
</body>
</html>
  • children.html

{# 继承自另一个模板 #}
{% extends 'parents.html' %}

{# 根据block可以修改原有的block内容 #}
{% block title %}子模板标题{% endblock %}

{% block body %}
    {# 保留基础模板中的内容 #}
    {{ super() }}
    <div>新加的内容</div>
{% endblock %}

提醒:若在子模板重写了一个block,原来的显示效果全丢了,八成的原因是忘记书写{{ super() }}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值