django自定义模板标签过程解析
这篇文章主要介绍了django自定义模板标签过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
代码布局
自定义模板标签必须位于django的某个应用中
该应用中新建templatetags目录,和models.py,views.py同一级别
结构如下:
polls/ __init__.py models.py templatetags/ __init__.py poll_extras.py views.py
模板中调用标签:
{%loadpoll_extras%}
为了让load标签工作,该标签所在应用必须在INSTALLED_APPS中
templatetags里有多少个模块没有限制,因为{%load%}会载入给定模块名的标签过滤器,而不是应用的名称
为了成为一个可用的标签库,必须注册,放在模块顶部
fromdjangoimporttemplate register=template.Library()
自定义标签过滤器
自定义过滤器就是一个带有一个或两个参数的Python函数:
- (输入的)变量的值——不一定是字符串形式。
- 参数的值——可以有一个初始值,或者完全不要这个参数。
例如,在{{var|foo:"bar"}}中,foo过滤器应当传入变量var和参数"bar"。
defcut(value,arg): """Removesallvaluesofargfromthegivenstring""" returnvalue.replace(arg,'')
下面是这个过滤器应该如何使用:
{{somevariable|cut:"0"}}
大多数过滤器没有参数。在这种情况下,你的函数不带这个参数即可。示例︰
deflower(value):#Onlyoneargument. """Convertsastringintoalllowercase""" returnvalue.lower()
注册自定义过滤器
方法1:
register.filter('cut',cut) register.filter('lower',lower)
Library.filter()方法需要两个参数:
过滤器的名称(一个字符串对象)
编译的函数–一个Python函数(不要把函数名写成字符串)
方法2:register.filter()用作装饰器
@register.filter(name='cut') defcut(value,arg): returnvalue.replace(arg,'') @register.filter deflower(value): returnvalue.lower()
下边是实例:
my.pyfromdjangoimporttemplate register=template.Library() @register.filter defmyadd(param): res=param+"************************" returnres @register.filter defmycul(param,num): res=param*num returnres
views.pydeftags(request): print("hello") returnrender(request,'mytags.html')
tags.html {%loadmy%} {{'tags'|myadd}} {{'tags'|mycul:5}}
结果:
tags************************tagstagstagstagstags
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。