过滤器:
过滤器的本质就是函数。有时候我们不仅仅只是需要输出变量的值,我们还需要修改变量的显示,甚至格式化、运算等等,这就用到了过滤器。 过滤器的使用方式为:变量名 | 过滤器。 过滤器名写在变量名后面,中间用 | 分隔。如:{{variable | capitalize}},这个过滤器的作用:把变量variable的值的首字母转换为大写,其他字母转换为小写。 其他常用过滤器如下:
字符串操作:
safe:禁用转义;
{{ 'hello' | safe }}
capitalize:把变量值的首字母转成大写,其余字母转小写;{{ 'hello' | capitalize }}
lower:把值转成小写;{{ 'HELLO' | lower }}
upper:把值转成大写;{{ 'hello' | upper }}
title:把值中的每个单词的首字母都转成大写;{{ 'hello' | title }}
trim:把值的首尾空格去掉;{{ ' hello world ' | trim }}
reverse:字符串反转;{{ 'olleh' | reverse }}
format:格式化输出;{{ '%s is %d' | format('name',17) }}
striptags:渲染之前把值中所有的HTML标签都删掉;{{ 'hello' | striptags }}
列表操作 first:取第一个元素{{ [1,2,3,4,5,6] | first }}
last:取最后一个元素{{ [1,2,3,4,5,6] | last }}
length:获取列表长度{{ [1,2,3,4,5,6] | length }}
sum:列表求和{{ [1,2,3,4,5,6] | sum }}
sort:列表排序{{ [6,2,3,1,5,4] | sort }}
语句块过滤(不常用): {% filter upper %} this is a Flask Jinja2 introduction {% endfilter %} 自定义过滤器: 过滤器的本质是函数。当模板内置的过滤器不能满足需求,可以自定义过滤器。自定义过滤器有两种实现方式:一种是通过Flask应用对象的add_template_filter方法。还可以通过装饰器来实现自定义过滤器。自定义的过滤器名称如果和内置的过滤器重名,会覆盖内置的过滤器。
实现方式一:通过调用应用程序实例的add_template_filter方法实现自定义过滤器。该方法第一个参数是函数名,第二个参数是自定义的过滤器名称。
def filter_double_sort(ls):
return ls[::2]
app.add_template_filter(filter_double_sort,‘double_2’)
实现方式二:用装饰器来实现自定义过滤器。装饰器传入的参数是自定义的过滤器名称。
@app.template_filter(‘db3’)
def filter_double_sort(ls):
return ls[::-3]