Django 的filter和tag
1、django的filter 和 tag == vue实例里 filter属性
django自带过滤器(filter)
可以对服务端返回的数据进一步加工。
使用方式
1.0、在html当中通过{{ navs|length }}进行使用
----filter练习<br>
{{ navs }}<br>
{{ navs|length }}---长度<br>
{{ navs.0 }}---获取第一个元素<br>
{{ navs|slice:'0:4' }}---切片<br>
{{ navs|truncatechars:6 }}--包括...在内显示6个字符剩下的省略<br>
{{ navs|join:'=' }}--拼接,如果是字符串,每个字符串用=拼接<br>
length是django自带的过滤器,在使用{{ navs|length }} 实际是将navs传递给length 由length返回当前变量长度。
1.1、{{ navs|truncatechars:6 }}
truncatechars是个方法,navs当做第一个参数传递给truncatechars,6 当做第二个参数传递给truncatechars
注:filter 最多 接收2个参数。
自定义filter–最多能接受2个参数
<div>
1、在app的根目录创建templatags目录
2、创建tmpTags.py文件
3、固定导入
from django import template
register = template.Library()
4、使用装饰器 @register.filter 修饰自定义的filter方法
5、例如
from django import template
register = template.Library()
#自定义的filter
@register.filter
def filter_demo(x,y):
return x+y
6、在html中导入{% load tmpTags %}
7、使用 { 1|filter_demo:2 }}
8、filter最多支持2个参数,管道符左侧为第一个参数,冒号后为第二个参数
</div>
-------实现接收2个参数
-------实现自定义,实现返回成功或者失败
from django import template
register = template.Library()
#自定义的filter
@register.filter
def filter_demo(x,y):
return x+y
@register.filter
def filter_demo1(x):
if x==1:
return '成功'
else:
return '失败'
自定Tag(可以接收多个参数)
<div>
1、在app的根目录创建templatags目录
2、创建tmpTags.py文件
3、固定导入
from django import template
register = template.Library()
4、使用装饰器 @register.simple_tag 修饰自定义的filter方法
5、例如
@register.simple_tag
def test_simple_tag(x,y,z):
return x+y+z
6、在html中导入{% load tmpTags %}
7、使用
----自定义的tag练习<br>
{% load tmpTags %}
{% test_simple_tag 1 2 3 %}<br>
8、simple_tag可以支持多个参数,通过空格分隔
</div>