赞
踩
Jinja2是Python下一个被广泛应用的模版引擎,要想使用Jinja2模板,需要从flask导入render_template函数,然后在路由函数中调用render_template函数,如果要传数据给前端用render_template携带参数
前端接收后端传的数据用{{变量名}}
过滤器的本质就是函数。有时候我们不仅仅只是需要输出变量的值,我们还需要修改变量的显示,甚至格式化、运算等等,而在模板中是不能直接调用 Python 中的某些方法,那么这就用到了过滤器。
{{variable | filter_name}}
{{ ‘hello’ | safe }}
{{ ‘hello’ | capitalize }}
{{ ‘HELLO’ | lower }}
{{ ‘hello’ | upper }}
{{ ‘hello’ | title }}
{{ ‘olleh’ | reverse }}
{{ ‘%s is %d’ | format(‘name’,17) }}
{{ ‘hello’ | striptags }}
{{ ‘hello every one’ | truncate(9)}}
{{ [1,2,3,4,5,6] | first }}
{{ [1,2,3,4,5,6] | last }}
{{ [1,2,3,4,5,6] | length }}
{{ [1,2,3,4,5,6] | sum }}
{{ [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” %}
可以将它看成时Jinja2中的一个函数,它会返回一个模板或者HTML字符串
可以将相同的重复编写的模板代码封装到宏中
语法:
{% macro func() %}
{% endmacro %}
调用:
{{ func() }}
实例:
创建宏
{% macro input(label='', type='text', name='', value='') %}
<label>{{ label }}</label><input type="{{ type }}" name="{{ name }}" value="{{ value }}"><br>
{% endmacro %}
使用宏
<form action="">
{{ input(label='⽤用户名:', name='user_name') }}
{{ input(label='邮箱:', name='email') }}
{{ input(label='密码:', type='password', name='password') }}
{{ input(label='确认密码:', type='password', name='password2') }}
{{ input(type='submit', value='提交') }}
</form
超链接中的反向解析,和重定向中的反向解析用法一致
比如在视图函数中定义了
@app.route('/login')
def login():
return "欢迎你的到来"
然后模板中:
<a href="{{ url_for('login') }}">登录</a>
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。