Jinja2模板
Flask
使用Jinja2
这个模板引擎来渲染模板。Jinja2
能识别所有类型的变量,包括{}
。 Jinja2
模板引擎,Flask
提供的render_template
函数封装了该模板引擎,render_template
函数的第一个参数是模板的文件名,后面的参数都是键值对,表示模板中变量对应的真实值。
Jinja2官方文档
- 基本语法
flask 中的render_template
渲染模板
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Template</title>
</head>
<body>
<h1>hello {{ name }}</h1>
</body>
</html>
@app.route("/")
def index():
return render_template("index.html", name="python")
- 在模板中{{ variable }}结构表示变量,是一种特殊的占位符,告诉模板引擎这个位置的值,从渲染模板时使用的数据中获取;Jinja2除了能识别基本类型的变量,还能识别{};
<p>{{mydict['key']}}</p>
<p>{{mydict.key}}</p>
<p>{{mylist[1]}}</p>
<p>{{mylist[myintvar]}}</p>
from flask import Flask,render_template
app = Flask(__name__)
@app.route('/')
def index():
mydict = {'key':'python'}
mylist = ['puthon', 'c','java']
myintvar = 0
return render_template('vars.html',
mydict=mydict,
mylist=mylist,
myintvar=myintvar
)
if __name__ == '__main__':
app.run(debug=True)
过滤器
- 字符串过滤器
# safe:禁用转义;
<p>{{ '<em>hello</em>' | safe }}</p>
# capitalize:把变量值的首字母转成大写,其余字母转小写;
<p>{{ 'hello' | capitalize }}</p>
# lower:把值转成小写;
<p>{{ 'HELLO' | lower }}</p>
# upper:把值转成大写;
<p>{{ 'hello' | upper }}</p>
# title:把值中的每个单词的首字母都转成大写;
<p>{{ 'hello' | title }}</p>
# trim:把值的首尾空格去掉;
<p>{{ ' hello world ' | trim }}</p>
# reverse:字符串反转;
<p>{{ 'olleh' | reverse }}</p>
# format:格式化输出;
<p>{{ '%s is %d' | format('name',17) }}</p>
# striptags:渲染之前把值中所有的HTML标签都删掉;
<p>{{ '<em>hello</em>' | striptags }}</p>
- 列表过滤器
# first:取第一个元素
<p>{{ [1,2,3,4,5,6] | first }}</p>
# last:取最后一个元素
<p>{{ [1,2,3,4,5,6] | last }}</p>
# length:获取列表长度
<p>{{ [1,2,3,4,5,6] | length }}</p>
# sum:列表求和
<p>{{ [1,2,3,4,5,6] | sum }}</p>
# sort:列表排序
<p>{{ [6,2,3,1,5,4] | sort }}</p>
- 自定义过滤器
def list_step_2(li):
"""自定义的过滤器"""
return li[::2]
# 注册过滤器
app.add_template_filter(list_step_2, "li2")
# 通过装饰器,注册过滤器
app.template_filter(模板中使用的装饰器名字)
<p>my_list: {{my_list | li2}}</p>
控制语句
- if语句
{% if %} {% endif %} - for语句
{% for item in samples %} {% endfor %}