模板变量 : {{name}}

1. 模板的定义: 模板变量 : {{name}}
2. 模板的渲染:  render_template("模板名字",键=值,键=值)
        例如:  render_template("index.html",name="python",age="18")
      如果传值的话,想要直接在渲染函数里面直接传字典则:
      可以事先定义好一个字典data,然后,render_template("index.html",**data)

首先是模板,里面的变量的写法和python的是一样的,   如下面的   index.html  (放在自建的templates目录下面)

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title>
</head>
<body><p>name = {{ name }}</p><p>age = {{ age }}</p><p>my_dict: city={{ my_dict["city"] }}</p><p>my_dict: city={{ my_dict.city}}</p><p>my_list : {{ my_list }}</p><p>my_list[my_int] : {{my_list[my_int] }}</p><p>my_list[0] + my_list[1] : {{ my_list[0] + my_list[1] }}</p>
</body>
</html>

然后在程序中怎么进行渲染

from flask import Flask, render_templateapp = Flask(__name__)@app.route("/index")
def index():data = {"name": "python","age": 18,"my_dict": {"city": "sz"},"my_list": [1, 2, 3, 4, 5],"my_int": 0}#  render_template("index.html",name="python",age="18")  """也可以进行直接传递一个字典进去,但是字典的前面要加上两个星号"""return render_template("index.html", **data)if __name__ == '__main__':app.run(debug=True)

运行的结果,就会按照模板里面取里面的值的方式,取出相应的值,    输入127.0.0.1:5000/index

 过滤器

1.字符串过滤器

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>

2.支持链式使用过滤器

<p>{{ “ hello world  “ | trim | upper }}</p>

3.列表过滤器

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>

自定义的过滤器

自定义的过滤器名称如果和内置的过滤器重名,会覆盖内置的过滤器。

方式一:

通过 add_template_filter (过滤器函数, 模板中使用的过滤器名字)


def list_step_2(li):"""自定义的过滤器"""return li[::2]   # 让列表隔一个取一个"""自定义的过滤器要进行注册"""
# 第一个参数是函数名,第二个是过滤器名字
app.add_template_filter(list_step_2,"li2")

方式二:

通过装饰器  app.template_filter (模板中使用的装饰器名字)

@app.add_template_filter("li")
def list_step_2(li):"""自定义的过滤器"""return li[::2]   # 让列表隔一个取一个

在模板中直接接收:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title>
</head>
<body><p>{{my_list | li2}}</p>
</body>
</html>

Flask框架(flask模板(jinja2)与字符串过滤器、列表过滤器以及自定义过滤器)相关推荐

  1. flask框架中的Jinja2模板引擎

    简介 在flask框架中通常使用Jinja2模板引擎来实现复杂页面的渲染. 本章主要介绍Jinja2模板引擎的基本结构和使用方法. 如何使用flask框架渲染模板 在模板中传递一个或者多个参数 if语 ...

  2. Flask框架之模板继承与案例05

    Flask框架之模板继承与案例05 一,模版继承 二,静态文件的配置 1.这里列举一个小例子: 三,模版案例(制作豆瓣评分页面) 1.效果图: 2.数据准备: 3.代码链接 一,模版继承 Flask中 ...

  3. Flask服务端模板(Jinja2) SSTI 注入漏洞

    漏洞简介 flask/ssti漏洞,即: Flask(Jinja2) 服务端模板注入漏洞(SSTI).Flask 是一个使用 Python 编写的轻量级 Web 应用框架,Flask 为你提供工具,库 ...

  4. Flask框架可视化模板

    文章目录 models static templates views manage app子文件 html error.html echarts.html echarts2.html main.htm ...

  5. Flask框架(flask中的蓝图Blueprint)

    1. 我们学习Flask框架,开始的时候是把所有的视图函数等都写在一个文件中 我们在这单个文件中可以定义路由.视图函数.定义模型等等. 但这显然存在一个问题:随着业务代码的增加,将所有代码都放在单个程 ...

  6. Flask框架(flask中的数据库SQLAlchemy(python3),配置、模型类、创建表)

    1.  SQLAlchemy是一个关系型数据库框架, 它提供了高层的ORM和底层的原生数据库的操作. flask-sqlalchemy是一个简化了SQLAlchemy操作的flask扩展. 2. 安装 ...

  7. Web框架之Django_04 模板层了解(过滤器、标签、自定义过滤器、标签、inclusion_tag、模板的继承与导入)

    阅读目录 一.模板语法: 二.过滤器:(Filters) 三.模板的继承与模板的导入 摘要: 模版层(模板语法) 模板语法 过滤器 标签 自定义过滤器.标签 inclusion_tag 模板的继承 模 ...

  8. Flask框架(flask中设置和获取session)

    1. session 数据是保存到后端的数据库中 2.session中的从狭义和广义上分:   (1)session,广义上 :          是一种机制:在前端当中存一个session_id , ...

  9. Flask框架(flask中设置响应信息的方法,返回json数据的方法)

    设置响应信息的方法 1.  返回自定义的响应头,有两种方式: (1)  第一种是:视图函数return的时候,使用元组,返回自定义的信息           返回的时候的状态码可以自定义信息:&quo ...

最新文章

  1. 项目梳理6——使用WebApiTestClient为webapi添加测试
  2. android 之适配器与json对象解析技术的联用的进一步优化(解决图片错位)
  3. java oo原则_javaOO11-12:面向对象的设计原则、线程
  4. C++中内存分配方式、空指针及野指针的区别
  5. linux 变量c file代表的内容.,LinuxC编程基础--mak.ppt
  6. mysql必知必会和sql必知必会
  7. 模2运算 / 模2算法(模2加法、模2减法、模2乘法、模2除法)
  8. C# chart控件使用方法
  9. 轮廓检测论文解读 | 整体嵌套边缘检测HED | CVPR | 2015
  10. colorbox加载ajax调用的html页面,jQuery的弹出窗口 ColorBox
  11. 最近大火的 NFT 数字藏品是什么?
  12. 博世XC事业部李胤:自动驾驶降温不意外,但这条路肯定会走下去
  13. 微信小程序之实现到商品列表跳转商品详情页
  14. RabbitMQ3:RabbitMQ的使用方法
  15. 联想教育应用使用说明(7.6版本)——第0章 目录
  16. [附源码]Python计算机毕业设计大众点评管理系统
  17. CSS餐厅小游戏练习1~32关(附答案和链接)
  18. 基于Airtest陀螺世界辅助源代码
  19. 【RPG Maker MV】使用技巧1:用自己绘制的图片当做地图
  20. hover 鼠标悬浮改变样式

热门文章

  1. 简单几行代码带你快速了解淘宝双十一的强大技术支撑点Sentinel+Nacos
  2. 4j 设置日志保存天数_MySQL中的这几类日志,你一定要知道
  3. 【学习笔记】rabbitmq设置队列ttl和使用延迟插件的代码示例
  4. Kotlin实战指南三:流程控制
  5. Android Studio添加aar
  6. android XMl 解析神奇xstream 二: 把对象转换成xml
  7. ARKit从入门到精通(7)-ARCamera介绍
  8. Android构建流程——篇八
  9. 使用Hexo 搭建 blog过程
  10. 编译boost相关文件