django自定义模板标签
代码布局
自定义模板标签必须位于django的某个应用中
该应用中新建templatetags目录,和models.py,views.py同一级别
结构如下:
polls/ __init__.py models.py templatetags/ __init__.py poll_extras.py views.py
模板中调用标签:
{% load poll_extras %}
为了让load标签工作,该标签所在应用必须在INSTALLED_APPS中
templatetags里有多少个模块没有限制,因为{% load %}会载入给定模块名的标签过滤器,而不是应用的名称
为了成为一个可用的标签库,必须注册,放在模块顶部
from django import template register=template.Library()
自定义标签过滤器
自定义过滤器就是一个带有一个或两个参数的Python 函数:
- (输入的)变量的值 —— 不一定是字符串形式。
- 参数的值 —— 可以有一个初始值,或者完全不要这个参数。
例如,在{{ var|foo:"bar" }}
中,foo
过滤器应当传入变量var
和参数 "bar"
。
def cut(value, arg): """Removes all values of arg from the given string""" return value.replace(arg, '')
下面是这个过滤器应该如何使用:
{{ somevariable|cut:"0" }}
大多数过滤器没有参数。在这种情况下,你的函数不带这个参数即可。示例︰
def lower(value): # Only one argument. """Converts a string into all lowercase""" return value.lower()
注册自定义过滤器
方法1:
register.filter('cut', cut) register.filter('lower', lower)
Library.filter()
方法需要两个参数:
- 过滤器的名称(一个字符串对象)
- 编译的函数 – 一个Python函数(不要把函数名写成字符串)
方法2:register.filter()
用作装饰器
@register.filter(name='cut') def cut(value, arg): return value.replace(arg, '') @register.filter def lower(value): return value.lower()
接下来,在模板中load,调用标签就可以了
下边是实例:
my.py
from django import template register=template.Library() @register.filter def myadd(param): res=param+"************************" return res @register.filter def mycul(param,num): res=param*num return res
views.py
def tags(request): print("hello") return render(request,'mytags.html')
tags.html
<body> {% load my %} {{ 'tags'|myadd }} {{ 'tags'|mycul:5 }} </body>
结果:
tags************************ tagstagstagstagstags