自定义模板过滤器
{
{ 参数1|过滤器的名 }}
{
{ 参数1|过滤器:参数2 }}
虽然DTL给我们内置了许多好用的过滤器。但是有些时候还是不能满足我们的需求。因此Django给我们提供了一个接口,可以让我们自定义过滤器,实现自己的需求。
过滤器实际上就是python中的一个函数,只不过是把这个函数注册到模板库中,以后在模板中就可以使用这个函数了。但是这个函数的参数有限制,第一个参数必须是这个过滤器需要处理的值,第二个参数可有可无,如果有,那么就意味着在模板中可以传递参数。并且过滤器的函数最多只能有两个参数。
自定义过滤器的步骤:
- 首先在某个app中,创建一个python包,叫做templatetags,注意,这个包的名字必须为templatetags,不然就找不到。
- 在这个templatetags包下面,创建一个python文件用来存储过滤器。
- 在新建的python文件中,定义过滤器(也就是函数),这个函数的第一个参数永远是被过滤的那个值,并且如果在使用过滤器的时候传递参数,那么还可以定义另外一个参数。但是过滤器最多只能有2个参数。
在写完过滤器(函数)后,要使用django.template.Library.filter进行注册,文件my_filter.py。
from django import template register = template.Library() def greet(value,word): return value + word register.filter("greet",greet)
- 还要把这个过滤器所在的这个app添加到settings.INSTALLED_AAPS中,不然Django也找不到这个过滤器。
- 在模板中使用load标签加载过滤器所在的python包。(文件index.html)
{% load my_filter %}
- 可以使用过滤器了。
- django.template.Library.filter还可以当作装饰器来使用。如果filter函数没有传递任何参数,那么将会使用这个函数的名字来作为过滤器的名字。当然如果你不想使用函数的名字来作为过滤器的名字,也可以传递一个name参数。