python Flask之JinJa2

文章目录

什么是jinja2

Jinja2是Python下一个被广泛应用的模版引擎,要想使用Jinja2模板,需要从flask导入render_template函数,然后在路由函数中调用render_template函数

过滤器

过滤器的本质就是函数。有时候我们不仅仅只是需要输出变量的值,我们还需要修改变量的显示,甚至格式化、运算等等,而在模板中是不能直接调用 Python 中的某些方法,那么这就用到了过滤器。

使用方式:

{{variable | filter_name}}

常见的过滤器

字符串操作

  • safe:加上标签就是HTML语法

    {{ ‘hello’ | safe }}

  • capitalize:把变量值的首字母转成大写,其余字母转小写

    {{ ‘hello’ | capitalize }}

  • lower:把值转成小写

    {{ ‘HELLO’ | lower }}

  • upper:把值转成大写

    {{ ‘hello’ | upper }}

  • title:把值中的每个单词的首字母都转成大写  

    {{ ‘hello’ | title }}

  • reverse:字符串反转

    {{ ‘olleh’ | reverse }}

  • format:格式化输出

    {{ ‘%s is %d’ | format(‘name’,17) }}

  • striptags:渲染之前把值中所有的HTML标签都删掉

    {{ ‘hello’ | striptags }}

  • truncate: 字符串截断

    {{ ‘hello every one’ | truncate(9)}}

列表操作

  • first:取第一个元素

    {{ [1,2,3,4,5,6] | first }}

  • last:取最后一个元素

    {{ [1,2,3,4,5,6] | last }}

  • length:获取列表长度

    {{ [1,2,3,4,5,6] | length }}

  • sum:列表求和

    {{ [1,2,3,4,5,6] | sum }}

  • sort:列表排序

    {{ [6,2,3,1,5,4] | sort }}

自定义过滤器两种方法

当模板内置的过滤器不能满足需求,可以自定义过滤器。自定义过滤器有两种实现方式:

方法一(调用)

def do_listreverse(li):
    # 通过原列表创建一个新列表
    temp_li = list(li)
    # 将新列表进行返转
    temp_li.reverse()
    return temp_li

app.add_template_filter(do_listreverse,'lireverse')
通过调用应用程序实例的 add_template_filter 方法实现自定义过滤器

该方法第一个参数是函数名,第二个参数是自定义的过滤器名称:

方法二(装饰器)

@app.template_filter('lireverse')
def do_listreverse(li):
    # 通过原列表创建一个新列表
    temp_li = list(li)
    # 将新列表进行返转
    temp_li.reverse()
    return temp_li

流程控制语句:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>控制语句</title>
</head>
<body>
    {# 如果姓名name是Warren,就打印名字,否则打印其他信息 #}
    {% if users[0].name == "Warren" %}
        <p>{{ users[0].name }}</p>
        <p>用户名是Warren</p>
    {% else %}
        <p>用户名不是Warren</p>
    {% endif %}

    {# for循环 #}
    <h3>遍历列表</h3>
    <table>
        <thead>
            <th>姓名</th>
            <th>年龄</th>
        </thead>
        <tbody>
            {% for user in users %}
                <tr>
                    <td>{{ user.name }}</td>
                    <td>{{ user.age }}</td>
                </tr>
            {% endfor %}
        </tbody>
    </table>

    <h3>遍历字典</h3>
    {% for key, value in groups.items() %}
        <p>key: {{ key }};value: {{ value }}</p>
    {% endfor %}
</body>
</html>

总结 : 所有的控制语句都是通过{% statement %}来使用,并且都有一个结束语句{% endstatement %},Python中的>, <, !=, >=等判断都可以用在if里,也可以通过and, or,not等进行逻辑判断。

模板继承

多个页面具有完全相同的顶部和底部内容或则有完全相同的 html 代码块内容

语法:

{% block top %} {% endblock %}

相当于在父模板中挖个坑,当子模板继承父模板时,可以进行填充。

子模板使用 extends 指令声明这个模板继承自哪个模板

父模板中定义的块在子模板中被重新定义,在子模板中调用父模板的内容可以使用super()

父模板代码:

base.html

{% block top %}
  顶部菜单
{% endblock top %}
​
{% block content %}
{% endblock content %}
​
{% block bottom %}
  底部
{% endblock bottom %}

子模板代码:

extends指令声明这个模板继承父类

{% extends ‘base.html’ %}
{% block content %}
需要填充的内容
如果还要
{% endblock content %}

include标签:

这个标签相当于是直接将指定的模版中的代码复制粘贴到当前位置。

{% include “common/footer.html” %}

上一篇:ssh项目在Action中实例化的Biz对象为null,找不到Biz报空指针异常


下一篇:6月9号