Flask Jinja2模板引擎

水深无声 2022-12-23 11:17 329阅读 0赞

简介

Jinja2是Python下一个被广泛应用的模版引擎,他的设计思想来源于Django的模板引擎,并扩展了其语法和一系列强大的功能。其中最显著的一个是增加了沙箱执行功能和可选的自动转义功能,这对大多应用的安全性来说是非常重要的(来源百度百科)。

Jinja2模板

Flask是一款开发Web服务端的框架,所以肯定是离不开页面的。上一章,我们使用路由返回数据时,返回内容中包含的有少量的HTML代码,如果需要的HTML代码多了,就很繁琐了,这时我们就可以使用Jinja2模板引擎。

  • Flask提供的 render_template 函数封装了Jinja2模板引擎;
  • render_template 函数的第一个参数是模板的文件名,后面的参数都是键值对,表示向模板中传递的参数值。

基本使用

创建一个视图函数渲染模板以及设置模板参数。

  1. @app.route("/hello/<name>")
  2. def hello(name):
  3. return render_template("hello.html", name=name)

render_template函数第一个参数对应的是模板的文件名,后面的参数为向模板中传递的参数值。
Flask在程序文件夹中的templates子文件夹中根据模板文件名来寻找对应的模板。
所以需要在templates子文件夹下定义一个hello.html文件。
在这里插入图片描述
代码如下:

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>Title</title>
  6. </head>
  7. <body>
  8. {# name为视图函数传递过来的参数 #}
  9. <h1>Hello, {
  10. { name }}!</h1>
  11. </body>
  12. </html>

其中用 { {}} 来表示变量名,用于接收视图函数传递的参数,其变量名与视图函数传递的键名需要一致;
{# #} 表示注释,注释的内容不会在html中被渲染出来。运行效果如下:

在这里插入图片描述
上面使用模板接收了简单的变量,除此之外还可以接收字典,列表,对象和获取session中的内容等。下面来看一下使用模板接收一些复杂的类型数据。
修改后的视图函数代码:

  1. @app.route("/hello/<name>")
  2. def hello(name):
  3. mydict = {
  4. "name": '李四',
  5. 'age': 18
  6. }
  7. mylist = ['aaa', 'bbb', 'ccc']
  8. session['name'] = "abc"
  9. return render_template("hello.html", name=name, mydict=mydict, mylist=mylist);

模板页面代码:

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>Title</title>
  6. </head>
  7. <body>
  8. <h1>Hello, {
  9. { name }}!</h1>
  10. <h1>获取字典数据:{
  11. { mydict['name'] }} --- {
  12. { mydict['age'] }}</h1>
  13. <h1>获取列表数据:{
  14. { mylist[1] }}</h1>
  15. <h1>通过过滤器修改变量(把值转换为大写形式):{
  16. { mylist[0] | upper }}</h1>
  17. <h1>获取session中的内容:{
  18. { session.get("name") }}</h1>
  19. <h1>请求头信息:{
  20. { request.headers }}</h1>
  21. </body>
  22. </html>

运行效果如下:
在这里插入图片描述

除了上面用到的upper过滤器,Jinja2还提供了很多过滤器,如下是Jinja2常用的过滤器。






































过滤器名 说明
safe 渲染值时不转义
capitalize 把值的首字母转换成大写,其他字母转换成小写
lower 把值转换成小写形式
upper 把值转换成大写形式
title 把值中每个单词的首字母都转换成大写
trim 把值的首尾空格去掉
striptags 渲染之前把值中所有的HTML标签都删掉

控制结构

Jinja2中提供了很多种控制结构,可以用来改变模块的渲染流程,如if、for等。
在Jinja2中使用if控制结构,语法格式和python的语法格式一样,但必须写在{% %}中,不同python的是有开始标签就必须要有结束标签。

  1. {% if comment %}
  2. <p>{
  3. { comment }}</p>
  4. {% else %}
  5. <p>comment字典为空</p>
  6. {% endif %}

for循环的使用,遍历一个字典中的所有数据。

  1. {% for user in users %}
  2. <p>姓名:{
  3. { user['name'] }}, 年龄:{
  4. { user['age'] }}</p>
  5. {% endfor %}

上述的变量都是在视图函数返回时传递的,视图函数代码如下:

  1. @app.route('/contro')
  2. def contro():
  3. users = [
  4. {"name": "张三", "age":20},
  5. {"name": "李四", "age":25},
  6. {"name": "王五", "age":16},
  7. {"name": "小华", "age":22}
  8. ]
  9. comment = []
  10. return render_template("contro.html", comment=comment, users=users)

页面完整代码

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>Title</title>
  6. </head>
  7. <body>
  8. {% if users %}
  9. {% for user in users %}
  10. <p>姓名:{
  11. { user['name'] }}, 年龄:{
  12. { user['age'] }}</p>
  13. {% endfor %}
  14. {% else %}
  15. <p>没有学生信息!</p>
  16. {% endif %}
  17. {% if comment %}
  18. <p>{
  19. { comment }}</p>
  20. {% else %}
  21. <p>comment字典为空</p>
  22. {% endif %}
  23. </body>
  24. </html>

运行效果如下
在这里插入图片描述

模板继承

在实际开发中有时候会有很多重复使用的模块代码片段,这时我们可以把这些模块代码写入一个单独的文件,需要用时,直接继承使用,以避免重复编写。
创建一个名为base.html的基模板,用于编写公共部分模块。代码如下。

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>
  6. {% block title %}
  7. {# 其他页面可以重写标题 #}
  8. {% endblock %}
  9. </title>
  10. {% block css %}
  11. {# 其他页面可以自定义加载样式文件 #}
  12. {% endblock %}
  13. </head>
  14. <body>
  15. {% block content %}
  16. {# 其他页面内容 #}
  17. {% endblock %}
  18. </body>
  19. </html>

block标签定义的元素可在继承模块中修改。上述定义了title、css、content三个模块,其他文件继承后可以重写这些模块中的内容。
新建一个模板文件继承base.html模板

  1. {# 继承base.htm模块 #}
  2. {% extends 'base.html' %}
  3. {% block title %}
  4. 重写base.htmltitle模块的内容
  5. {% endblock %}
  6. {% block content %}
  7. {# 重写base.htmlcontent模块内容 #}
  8. {% if users %}
  9. {% for user in users %}
  10. <p>姓名:{
  11. { user['name'] }}, 年龄:{
  12. { user['age'] }}</p>
  13. {% endfor %}
  14. {% else %}
  15. <p>没有学生信息!</p>
  16. {% endif %}
  17. {% if comment %}
  18. <p>{
  19. { comment }}</p>
  20. {% else %}
  21. <p>comment字典为空</p>
  22. {% endif %}
  23. {% endblock %}

extentds关键字声明继承base.html模块,之后重写了base.html模板中的title和content模块。运行效果如下:
在这里插入图片描述

发表评论

表情:
评论列表 (有 0 条评论,329人围观)

还没有评论,来说两句吧...

相关阅读

    相关 Flask Jinja2模板引擎

    简介 Jinja2是Python下一个被广泛应用的模版引擎,他的设计思想来源于Django的模板引擎,并扩展了其语法和一系列强大的功能。其中最显著的一个是增加了沙箱执行功

    相关 Flask Jinja2模板引擎

    模板 在前面的示例中,视图函数的主要作用是生成请求的响应,这是最简单的请求。实际上,视图函数有两个作用:处理业务逻辑和返回响应内容。在大型应用中,把业务逻辑和表现内容放在

    相关 Flask-jinja2

    渲染数据 数据准备 后端定义几个字符串,用于传递到前端 STUDENT = { 'name': 'Old', 'age': 38, 'gend