前情提要:
最近工作中用到django 中的
自定制过滤器的内容,
再此 复习一波过滤器和自定制 过滤器的内容
自定制过滤器
1、在settings中的INSTALLED_APPS配置当前app,不然django无法找到自定义的simple_tag.
2、在app中创建templatetags模块(模块名只能是templatetags)
3、创建任意 .py 文件,如:my_tags.py
django 自定制过滤器代码
from django import template from django.utils.safestring import mark_safe register = template.Library() # register的名字是固定的,不可改变 @register.filter def filter_multi(v1): msg= v1.pop() return msg @register.simple_tag def simple_tag_multi(v1, v2): return v1 * v2 @register.simple_tag def my_input(id,): result = "<input type='text' id='%s' />" % (id) return mark_safe(result)
前段代码
num 对应后端传过来的数据内容
视图代码
致此 自定制列内容 的所有内容都完成了
现在描述一下 系统自带的过滤器内容
Django过滤器
add过滤器:将字符串和字母、整数链接(若为字符串会转化为整数形式)
注:若是一个字母字符串和一个数字进行链接会输出空
{{ 1|add:2 }}返回一个3
{{ "2"|add:3 }}返回一个5
{{ "a"|add:3 }}#返回一个空
cut过滤器 移除指定的字符串注:后面的参数必须是字符串的形式
{{ "hello world"|cut:" " }}#移除了hello world 里的所有空格 结果为 helloworld
{{ "hello world"|cut:"e" }}#结果为hllo world 移除了e
{{ 123456|cut:1 }}#会报错 是因为参数不是字符串的形式 不管前面所要移除的对象是否为整数 参数必须是字符串的形式
data过滤器--过滤时间的过滤器(要用到datetime模块)
{{ time|date:"Y-m-g" }}#后面的参数必须要加引号 会显示出时间年月时分
first过滤器和last过滤器--输出列表/元组/字符串中的第一个 /最后一个值(不能传参数)
且元祖列表都要提前定义(只输入变量名)
#name:["ll","ww","ee"]
{{ name|first }}#输出li
{{ name|last }}#输出ee
{{ "15784"|first }}#字符串 输出1
floatformat过滤器--将浮点数保留小数 不传如参数就是默认保留一位(只看小数点后两位)
且正数和负数方式一样
{{ 1.41|floatformat }}#输出1.4
{{ 1.545|floatformat }}#输出1.5(只看小数点后两位等同于1.54)
{{ -1.05|floatformat }}#输出-1.1
{{ 1.247|floatformat:2 }}#输出1.25
join过滤器 在中间加一些特殊符号 类似于python的join(可以在列表,元祖操作)
{{ "hello"|join:"*" }}#输出h*e*l*l*o
{{ name|join:"-" }}
length过滤器 获取字符串、元祖、列表的长度(没有参数)
{{ "1515"|length }}#输出4
upper/lower过滤器 将字母改成大/小写(没有参数)
{{ "woaini"|upper }}#输出WOAINI
{{ "DEFRT"|lower }}#输出defrt
random过滤器 随机抽取列表、元祖、字符串中的随机一个数,类似于python中的random模块
{{ name|random }}#随机在这个里面输出一个值
safe过滤器 关闭字符串自动转义 就是传入的值里面没有任何特殊字符就会原样输出 若有就会转义输出(列入<br>),且python中的特殊字符无法识别
#"style": "abcdef<br>adasds"
{{ style|safe }}#会输出abcdef
adasds
#"style": "woaini"
{{ style|safe }}#会输出woaini(原样输出)
slice过滤器 类似于python的slice 切片(对字符串、元祖、列表操作)
{{ "woaini"|slice:"2" }}#输出wo(默认是从第0位开始到第2位结束,且不包含第二位)
{{ "woshini"|slice:"2:5" }}#输出shi
striptags过滤器 删除字符串中的html标签(前面的参数){{ value|striptags }} 中的value中的html标签(没有参数)
{{ style|striptags }}#输出一个不带有html标签的(style里有h1标签就会删除原样输出)
truncatechars过滤器 如果给定的字符串长度超过了过滤器指定的长度。那么就会进行切割,并且会拼接三个点来作为省略号
{{ "woaini"|truncatechars:5 }}#输出wo...本应输出woain但要用三个省略号作为末尾,所以就要输出wo...
{{ "woaini"|truncatechars:6 }}#输出woaini 字符串长度和过滤器指定长度相同 原样输出
注意:若value中带有html标签 不会自动转义 会自主输出
#"style": "<h1>abcdefadasds</h1>"
{{ style|truncatechars:6 }}#输出<h1..
truncatechars_html过滤器 和truncatechars过滤器类似只是不会切割html标签(输出的结果类似)
#"style": "<h1>abcdefadasds</h1>"
{{ style|truncatechars_html:5}}#输出<h1>ab...</h1>
default过滤器: 使用方式'{{ value | default('默认值')}}'。如果Value 这个‘key’不存在,那么就会使用‘default’过滤器提供的默认值。
如果你想使用类似于‘python’中判断某个值是否为false(例如:none,空字符串、空列表、空字典),
那么就必须传递另外一个参数‘{{value | default ('默认值',boolean = True)}}’
{{ "nlll"|default:"noneddd" }}#输出nlll 后面的值是False 就会输出value上写的值
default_if_none过滤器 只有值是none是才会用default_if_none提供的默认值 和default的关系是default包含defaul_if_none过滤器
{{ "nonon"|default_if_none:"1" }}#输出的值为nonon