由于Django的模板引擎和Flask中的Jinja2模板引擎有很多一样的地方,所以我将一样的地方总结到了独立的文章中

https://www.cnblogs.com/kuxingseng95/articles/9091027.html

变量

构造上下文

构造上下文前

 return render_template('test01_template.html', my_list=my_list, my_int=my_int, my_dict=my_dict)

构造上下文后

return render_template('test01_template.html', context=context)
return render_template('test01_template.html', **context)

比如:

from flask import Flask, render_template

app = Flask(__name__)

@app.route("/index")
def index():
# 处理业务逻辑
data = {
"name": "python",
"age": 18,
"my_li": [1, 2, 3, 4, 5, 6, 7],
"my_int": 0,
"my_dict": {
"city": "bj"
}
}
return render_template("code_18_templates.html", **data) if __name__ == '__main__':
app.run(debug=True)

和Django不同,在Flask的Jinja2模板引擎中,{{变量}}中是支持计算的

过滤器

jinja2中过滤器可以传入多个参数。

{{参数1 | 过滤器器(*args) }} 
{{ my_list2 | sum(‘age’) }}

而且支持链式调用

 {{ 'hello world' | reverse | upper }}

自定义过滤器

使用装饰器

from flask import Flask, render_template

app = Flask(__name__)

@app.route("/")
def index():
return render_template("code_19_filter.html") # 自定义过滤器
#  定义一个切片函数
@app.template_filter("li2") # 里面的参数表示过滤器的名字
def li_setup2(li):
# 每隔一个值获取一下
step = li[::2]
return step if __name__ == '__main__':
app.run()

直接添加到模板过滤器中

from flask import Flask, render_template

app = Flask(__name__)

@app.route("/")
def index():
return render_template("code_19_filter.html") #  定义一个切片函数
def li_setup2(li):
# 每隔一个值获取一下
return li[::2] # 自定义过滤器
# 第一个参数:表示自定义的函数名字,
# 第二个参数表示过滤器的名字
app.add_template_filter(li_setup2, "li2") if __name__ == '__main__':
app.run()

控制语句

与Django模板不同点

for循环后面可以拼接if语句

比较平时使用时我们需要这样:

{% for index in my_list %}
{% if index > 5 %}
{{ index }}
{% endif %}
{% endfor %}

而Flask中可以这样:

{% for index in my_list if index > 5 %}
{{index}}
{% endfor %}

比如在判断列表为空的时候

Django和jinja2也不一样

jinja2中

{% for index in my_list %}
{{index}}
{% else %}
没有值了
{% endfor %}

django中

{% for index in my_list %}
{{index}}
{% empty %}
没有值了
{% endfor %}

可以将它看成时Jinja2中的一个函数,它会返回一个模板或者HTML字符串

可以将相同的重复编写的模板代码封装到宏中

使用

标签

{% macro func() %}
{% endmacro %}

准备宏

{% 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>

封装宏

为了达到宏的复用,我们可以将宏单独的抽取到指定的html文件中

使用封装的宏

{% import 'macro.html' as func %}
<form action="">
{{ func.input(label='⽤用户名:', name='user_name') }}
{{ func.input(label='邮箱:', name='email') }}
{{ func.input(label='密码:', type='password', name='password') }}
{{ func.input(label='确认密码:', type='password', name='password2') }}
{{ func.input(type='submit', value='提交') }}
</form>

Flask中特有的模板变量和方法

特有变量

比如:

特有变量:

request:获取请求的数据

session:获取session数据

config:获取配置参数

g:获取视图中g变量存储的值

特有方法

url_for()

@app.route("/order/<order_id>")
def order(order_id):
return 'order %s' % order_id

超链接中的反向解析,和重定向中的反向解析用法一致

比如在视图函数中定义了

@app.route('/order')
def order():
return "order"

然后再模板中

<a href="{{ url_for('order') }}">进⼊入order</a>

可以进行反向的解析

反向的解析传参

@app.route("/order/<order_id>")
def order(order_id):
return "order %s" % order_id
<a href="{{ url_for('order', order_id=123) }}">进⼊入order</a>

get_flashed_messages()

搭配flask中国的flash()方法使用

flash()用于将视图中准备的提示信息添加到消息队列中

然后模板中使用get_flashed_messages()提取和展示视图中准备的提示信息

使用

{% for message in get_flashed_messages() %}
{{message}}
{% endfor %}

Flask-WTF表单

首先需要安装 Flask-WTF == 0.14.2

常用模块

表单类

from flask_wtf import FlaskForm 

字段

from wtforms import StringField, PasswordField, SubmitField 

验证器

from wtforms.validators import DataRequired, InputRequired, EqualTo

例子:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body> <form method="post"> {{ form.csrf_token }} {{ form.user_name.label }}
<p>{{ form.user_name }}</p>
{% for msg in form.user_name.errors %}
<p>{{ msg }}</p>
{% endfor %} {{ form.password.label }}
<p>{{ form.password }}</p>
{% for msg in form.password.errors %}
<p>{{ msg }}</p>
{% endfor %} {{ form.password2.label }}
<p>{{ form.password2 }}</p>
{% for msg in form.password2.errors %}
<p>{{ msg }}</p>
{% endfor %} {{ form.submit }} </form> </body>
</html>

前台代码

from flask import Flask, render_template
from flask import request
from flask_wtf import FlaskForm
from wtforms import StringField, PasswordField, SubmitField
from wtforms.validators import DataRequired, EqualTo app = Flask(__name__) class Config(object):
SECRET_KEY = "fadafsfafsafa" app.config.from_object(Config) # FlaskForm:继承flask的表单
class RegisterForm(FlaskForm):
# StringField :文本输入框
# validators :用来验证当前的文本输入框
# DataRequired:必须输入
user_name = StringField(label="用户名", validators=[DataRequired("必须填写用户名")])
password = PasswordField(label="密码", validators=[DataRequired("必须填写密码")])
# EqualTo : 判断两次密码是否相等
# password :  表示跟上面的密码进行判断,判断两次是否一致
password2 = PasswordField(label="确认密码", validators=[DataRequired("必须填写密码"), EqualTo("password", "两次密码必须一致")])
submit = SubmitField(label="提交") @app.route("/register", methods=["GET", "POST"])
def register():
if request.method == "GET":
form = RegisterForm()
return render_template("code_22_wtf.html", form=form)
else:
form = RegisterForm() if form.validate_on_submit(): name = form.user_name.data
pwd = form.password.data
pwd2 = form.password2.data
print(name, pwd)
return "注册成功"
else:
return render_template("code_22_wtf.html", form=form) if __name__ == '__main__':
app.run(debug=True)

后台代码

关于csrf

关于csrf的简单介绍:https://www.cnblogs.com/kuxingseng95/articles/9092333.html

防护措施

方案一:在FlaskForm中实现校验

在Flask-WTF扩展中,有一套完整的csrf防护体系

<form method="post">
{{ form.csrf_token() }}
{{ form.username.label }} {{ form.username }}<br/>
{{ form.password.label }} {{ form.password }}<br/>
{{ form.password2.label }} {{ form.password2 }}<br/>
{{ form.submit }}
</form>

方案二:单独使用

from flask.ext.wtf import CSRFPRrotect

CSRFProtect(app)

使用WTF拓展

同方案一

不使用WTF拓展

自己实现校验的所有逻辑

<form method="post" action="/">
<input type="hidden" name="csrf_token" value="{{ csrf_token() }}" />
</form>

flask模板语言的更多相关文章

  1. Flask - 模板语言jinja2 和render_template高级用法

    目录 Flask - 模板语言jinja2 和render_template高级用法 一. 字典传递至前端 二. 列表传入前端Jinja2 模板的操作: 三. 大字典传入前端 Jinja2 模板 四. ...

  2. flask模板语言,装饰器,路由及配置

    1.模板语言jinja2 Flask中默认的模板语言是Jinja2 1.0 模板传参 from flask import Flask,render_template app = Flask(__nam ...

  3. flask模板语言 jinja2 以及render_template 深度用法

    是时候开始写个前端了,Flask中默认的模板语言是Jinja2 现在我们来一步一步的学习一下 Jinja2 捎带手把 render_template 中留下的疑问解决一下 首先我们要在后端定义几个字符 ...

  4. Flask 模板语言,装饰器

      Jinja2模板语言 # -*- coding: utf-8 -*-   from flask import Flask, render_template, request, redirect,  ...

  5. Flask 模板语言

    Flask使用的是Jinja2模板引擎 举个例子: from flask import Flask, render_template app = Flask(__name__) @app.route( ...

  6. 【Flask】 Jinja2模板语言

    Jinja2 Jinja2是Python Web编程中的主流模板语言.因为flask是基于Jinja2和Werkzeug发展而来,在安装flask的时候jinja2自动就被装在上面了. 之前提到了很多 ...

  7. 第四篇flask中模板语言 jinja2

    Flask中默认的模板语言是Jinja2 首先我们要在后端定义几个字符串,用于传递到前端 STUDENT = {, 'gender': '中'}, STUDENT_LIST = [ {, 'gende ...

  8. Flask最强攻略 - 跟DragonFire学Flask - 第四篇 Flask 中的模板语言 Jinja2 及 render_template 的深度用法

    是时候开始写个前端了,Flask中默认的模板语言是Jinja2 现在我们来一步一步的学习一下 Jinja2 捎带手把 render_template 中留下的疑问解决一下 首先我们要在后端定义几个字符 ...

  9. python 全栈开发,Day119(Flask初识,Render Redirect HttpResponse,request,模板语言 Jinja2,用户登录例子,内置Session)

    一.Flask初识 首先,要看你学没学过Django 如果学过Django 的同学,请从头看到尾,如果没有学过Django的同学,并且不想学习Django的同学,轻饶过第一部分 三大主流Web框架对比 ...

随机推荐

  1. ajax 的三种使用方法

    第一种 也是最古老的一种方法之一 from 表单直接提交数据到php文件里 action为路径 <form method="post" action="./inde ...

  2. Mybatis源码解读-设计模式总结

    虽然我们都知道有26个设计模式,但是大多停留在概念层面,真实开发中很少遇到,Mybatis源码中使用了大量的设计模式,阅读源码并观察设计模式在其中的应用,能够更深入的理解设计模式. Mybatis至少 ...

  3. 关于web常见的安全问题

    一. Web攻击动机: 1.恶作剧: 2.关闭Web站点,拒绝正常服务: 3.篡改Web网页,损害企业名誉; 4.免费浏览收费内容; 5.盗窃用户隐私信息,例如手机号.Email等个人信息; 6.以用 ...

  4. nacos启动

    nacos下载 https://github.com/alibaba/nacos 1.执行数据库脚本 2.修改配置文件application.propertiesspring.datasource.p ...

  5. linux 和windows 的定时任务

    linux http://www.cnblogs.com/thinksasa/archive/2013/06/06/3121030.html windows http://www.myhack58.c ...

  6. Cordova 系列之Mac OS 环境配置

    1.从AppStore 安装xcode 2.安装node.js环境 http://nodejs.org/ 3.使用命令行安装 cordova 命令行帮助:http://cordova.apache.o ...

  7. python 基础(十三) time模块

    日期和时间 一.time模块 import time 时间戳: 时间戳是指格林威治时间1970年1月1日0时0分0秒至现在的秒数   s(秒).ms(毫秒).μs(微秒).ns(纳秒), ​ 其中:1 ...

  8. Unity Shader入门精要学习笔记 - 第14章非真实感渲染

    转载自 冯乐乐的 <Unity Shader 入门精要> 尽管游戏渲染一般都是以照相写实主义作为主要目标,但也有许多游戏使用了非真实感渲染(NPR)的方法来渲染游戏画面.非真实感渲染的一个 ...

  9. 如何在cmd中运行PHP

    我的php安装目录在 d:\php 那么 运行 cmd >d: >cd php 要让工作目录指向php.exe的安装文件夹 然后就可以用php指令了 比如 在该文件夹下面新建一个test. ...

  10. 如何写一个跨浏览器的事件处理程序 js

    如何 写一个合格的事件处理程序,看如下代码: EventUtil可以直接拿去用 不谢 <!DOCTYPE html> <html> <head> <title ...