1 模板引擎之过滤器

概念 : 过滤器本质上是个转换函数,第一个参数是待过滤的变量。如果它有第二个参数,模板中就必须传进去。

过滤器使用管道符| 放在{{ }}

Jinja2模板引擎提供了丰富的内置过滤器,主要分为以下几类:

(1) 字符串进行操作:

{# 当变量未定义时,显示默认字符串 #}
<p>{{ name | default('None', true) }}</p> {# 单词首字母大写 Yes#}
<p>{{ 'yes' | capitalize }}</p> {# 单词全小写 xml#}
<p>{{ 'XML' | lower }}</p> {# 去除字符串前后的空白字符 like#}
<p>{{ ' like ' | trim }}</p> {# 字符串反转,返回"olleh" #}
<p>{{ 'hello' | reverse }}</p> {# format格式化 #}
{{ '我叫%s 我今年%d岁了 我的存款为%.2f'|format('小胖子',38,1.00002) }} {# var|replace 替换 #}
{{ data.html|replace('h','x') }} {# 关闭HTML自动转义 #}
<p>{{ '<em>name</em>' | safe }}</p> {% autoescape false %}
{# HTML转义,即autoescape关了也转义,可以缩写为e #}
<p>{{ '<em>name</em>' | escape }}</p>
{% endautoescape %}

(2) 对列表进行操作

{# 取第一个元素12 #}
<p>{{ [12,21,33,44] | first }}</p> {# 取最后一个元素44 #}
<p>{{ [12,21,33,44] | last }}</p> {# 返回列表长度,可以写为count #}
<p>{{ [1,2,3,4,5] | length }}</p> {# 列表求和 #}
<p>{{ [12,21,33,44] | sum }}</p> {# 列表排序,默认为升序 #}
<p>{{ [12,21,33,44] | sort }}</p> {# 合并为字符串,返回"1 | 2 | 3 | 4 | 5" #}
<p>{{ [1,2,3,4,5] | join(' | ') }}</p> {# 列表中所有元素都全大写。这里可以用upper,lower #}
<p>{{ ['good','nice','handsome'] | upper }}</p>

(3) 对数值进行操作: 取证

{# 四舍五入取整,返回3 #}
<p>{{ 3.14169 | round }}</p> {# 向下截取到小数点后2位,返回3.14 #}
<p>{{ 3.14169 | round(2, 'floor') }}</p> {# 绝对值,返回15 #}
<p>{{ -15 | abs }}</p> {# var|list 将var值转换为列表 #}

(4) 类型转换

{# var|int 	将var值转换为整形 #}
{# var|string 将var值转换为字符串类型 #}
{# var|float 将var值转换为浮点形 #}
{# var|list 将var值转换为列表 #}

(5) 变量输出JSON格式字符串:一般结合javescript使用

<script type="text/javascript">
var arg = {{ args | tojson | safe }};
console.log(arg[1].name);
</script>

(6) 自定义过滤器

如果需要自定义过滤器,可以在主应用下定义个函数,因为过滤器本质也是函数

#定义过滤器函数
def filter(name):
return ....
#导入过滤器函数
app.add_template_filter(filter, 'fli')

2 模板引擎之测试器

概念: 测试器is返回结果为布尔值,一般与if控制语句搭配使用

(1)常见的内置测试器

{# 检查变量是否被定义,也可以用undefined检查是否未被定义 #}
{% if name is defined %}
<p>Name is: {{ name }}</p>
{% endif %} {# 检查是否所有字符都是大写 #}
{% if name is upper %}
<h2>"{{ name }}" are all upper case.</h2>
{% endif %} {# 检查变量是否为空 #}
{% if name is none %}
<h2>Variable is none</h2>
{% endif %} {# 检查变量是否为字符串,也可以用number检查是否为数值 #}
{% if name is string %}
<h2>{{ name }} is a string.</h2>
{% endif %} {# 检查变量是否可被迭代循环,也可以用sequence检查是否是序列 #}
{% if [1,2,3] is iterable %}
<h2>Variable is iterable.</h2>
{% endif %} {# 检查变量是否是字典 #}
{% if {'name':'test'} is mapping %}
<h2>Variable is dict.</h2>
{% endif %}

(2) 自定义测试器

#定义想实现的功能
def func(str):
return ...
#导入该功能
app.add_template_test(func,'测试器名')

3 全局函数

(1) dict函数,用于生成字典

{% set user = dict('username'='张三','password'=20) %}

(2) joiner()函数:用于分割循环,第一次为空字符串,以后每次都是分割符

{% set star = joiner('*') %}
{% for val in range(4) %}
{{ star }} {{ val }}
{% endfor %}

Flask入门模板过滤器与测试器(五)的更多相关文章

  1. flask模板的基本用法(定界符、模板语法、渲染模板),模板辅助工具(上下文、全局对象、过滤器、测试器、模板环境对象)

    flask模板 在动态web程序中,视图函数返回的HTML数据往往需要根据相应的变量(比如查询参数)动态生成. 当HTML代码保存到单独的文件中时,我们没法再使用字符串格式化或拼接字符串的当时在HTM ...

  2. Flask 页面缓存逻辑,jinja2 过滤器,测试器

    回调接入点-页面缓存逻辑 from flask import Flask,request,render_template from werkzeug.contrib.cache import Simp ...

  3. Flask入门模板Jinja2语法与函数(四)

    1 模板的创建 模板文件结构: project/ templates/ 模板文件 跳转模板一般使用: from flask import render_template,render_template ...

  4. Flask之模板过滤器

    3.2 过滤器: 过滤器的本质就是函数.有时候我们不仅仅只是需要输出变量的值,我们还需要修改变量的显示,甚至格式化.运算等等,这就用到了过滤器. 过滤器的使用方式为:变量名 | 过滤器. 过滤器名写在 ...

  5. Flask入门系列(转载)

    一.入门系列: Flask入门系列(一)–Hello World 项目开发中,经常要写一些小系统来辅助,比如监控系统,配置系统等等.用传统的Java写,太笨重了,连PHP都嫌麻烦.一直在寻找一个轻量级 ...

  6. Flask入门很轻松(三)—— 模板

    Jinja2模板引擎 转载请在文章开头附上原文链接地址:https://www.cnblogs.com/Sunzz/p/10959471.html Flask内置的模板语言,它的设计思想来源于 Dja ...

  7. Flask07 Jinja2模板测试器、控制语句IF/FOR、变量/块 赋值、作用域、块级作用域

    1 测试器及其使用 在模板中的 {{}} 可以书写测试器,格式如下 {{ 变量 is 测试器名称  }} 1.1 在python中导入 Jinja2 的模板 from jinja2 import te ...

  8. SpringBoot第五集:整合监听器/过滤器和拦截器(2020最新最易懂)

    SpringBoot第五集:整合监听器/过滤器和拦截器(2020最新最易懂) 在实际开发过程中,经常会碰见一些比如系统启动初始化信息.统计在线人数.在线用户数.过滤敏/高词汇.访问权限控制(URL级别 ...

  9. CPF 入门教程 - 设计器和模板库的使用(五)

    CPF netcore跨平台UI框架 系列教程 CPF 入门教程(一) CPF 入门教程 - 数据绑定和命令绑定(二) CPF 入门教程 - 样式和动画(三) CPF 入门教程 - 绘图(四) CPF ...

随机推荐

  1. abp 后台项目在IIS 中运行

    安装 Current .NET Core Hosting Bundle installer (direct download)

  2. 洛谷 P2048 BZOJ 2006 [NOI2010]超级钢琴

    题目描述 小Z是一个小有名气的钢琴家,最近C博士送给了小Z一架超级钢琴,小Z希望能够用这架钢琴创作出世界上最美妙的音乐. 这架超级钢琴可以弹奏出n个音符,编号为1至n.第i个音符的美妙度为Ai,其中A ...

  3. Luogu P1108 低价购买 DP

    第一问求最长下降子序列,不提: 第二问:借鉴了最短路的方法??? 我们求出来了每个位置的最长下降子序列的长度,那么刻意这样这样转移 if f[i]==f[j]+1&&a[i]<a ...

  4. JavaScript细节

    1.关于全局变量 全局变量在所有的作用域中都是可见变量.当程序小,代码量小的时候,可能还便于维护,而随着程序越来越复杂,代码量也随之越来越大后,过多的全局变量会变的很难处理.因为一个全局变量可以被程序 ...

  5. UVALive - 5963 ad-hoc

    注意到合法条件是对称的,那很有可能与2有关, 小于2表示没有这一页,大于2表示冲突了 我也不知道这样做对不对的(输入范围很迷),试一下就A了... #include<bits/stdc++.h& ...

  6. 文本编辑器 未完成 Treap

    #include<bits/stdc++.h> using namespace std; const int maxn = 2e6+1e5; unsigned int SEED = 17; ...

  7. 日志统计--蓝桥杯--vector

    /* 标题:日志统计 小明维护着一个程序员论坛.现在他收集了一份"点赞"日志,日志共有N行.其中每一行的格式是: ts id 表示在ts时刻编号id的帖子收到一个"赞&q ...

  8. nginx 反向代理导致的session丢失的问题

    [原文链接] https://blog.csdn.net/xiaweiyidengzhewo/article/details/80921750 注意这篇文章解释的是“丢失”而不是“一致性”

  9. vue项目echarts画布删除历史数据重新渲染数据

    vue用到echarts时,根据select多选下拉框进行echarts折线图渲染.发现折现只能增加不能减少,后来根据echarts API文档发现 调用方式: chart.setOption(opt ...

  10. zabbix_agent 主动模式配置

    一,主动与被动模式 默认的模式就是被动模式由服务端发送执行指令,客户端再执行 主动模式则为客户机自己找服务器拿任务执行 二,主动模式配置 查看客户端配置文件 grep '^[a-Z]' /etc/za ...