时间:2021-05-22
想要实现自定义标签和过滤器需要进行准备工作:
准备(必需)工作:
1 在某个app下创建一个名为templatetags(必需,且包名不可变)的包。假设我们在名为polls的app下创建了一个templatetags的包,并在该包下创建了一个名为mytags的文件。那么目录结构看起来应该就像这样:
polls/ __init__.py models.py templatetags/ __init__.py mytags.py views.py2 settings文件中的INSTALLD_APPS内必须含有该app。接下来,我们需要确认settings文件中的INSTALLED_APPS变量中已经有了polls
INSTALLED_APPS = ( 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'polls',)3 接下来在mytags文件中写入如下几行
from django import templateregister = template.Library()4 在模板中使用{% load %} 标签装载自定义标签或者装饰器
{% load mytags %}自定义过滤器:
1 自定义过滤器实际上就是写一个函数
2 django会将过滤器前的值传入该函数
3 函数完成后,需要进行登记register
因为第二步django已经帮我们完成,所以我们实际上只需要自己完成第一步和第三步
实例:写一个自动省略多余字符串的过滤器
1 定义一个 truncate_chars 函数
# 若字符串长度大于30,则省略之后的内容,否则原样输出该字符串。参数value就是过滤器前的值def truncate_chars(value): if value.__len__() > 30: return '%s......'% value[0:30] else: return value2 register该函数
# 登记register.filter('truncate_chars',truncate_chars)def truncate_chars(value): if value.__len__() > 30: return '%s......'% value[0:30] else: return valueLibrary.filter(name,function,is_safe=False,needs_autoescape=False,excepts_localtime=False)函数默认需要两个参数,name是装饰器的名称(字符串类型),function是函数名。后面三个参数可以参考 官方文档。 我们也可以通过装饰器进行登记
@register.filter(name='truncate_filter')def truncate_chars(value): if value.__len__() > 30: return '%s......'% value[0:30] else: return value如果没有使用name参数,django默认会将函数名作为name参数的值,所以下面的代码和上面的代码作用相同。
@register.filterdef truncate_chars(value): if value.__len__() > 30: return '%s......'% value[0:30] else: return value3 测试模板文件内容
{% load mytags %}<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>Title</title></head><body>{{ 'alskdjasdfasdfasdffasdfasdfasdffasdffasdffasdffasdfasdffasdffalskdjasdfasdfasdffasdfasdfasdffasdffasdffasdffasdfasdffasdff'|truncate_chars }}</body></html>4 浏览器显示结果
自定义标签
自定义标签相对于自定义过滤器来说要复杂很多,因为自定义标签可以做任何事情!
自定义标签分为很多类型
1 简单标签 Simple tags
2 内含标签 Inclusion tags
3 分配标签 Assignment tags
一 简单标签
import datetimefrom django import templateregister = template.Library()@register.simple_tagdef current_time(format_string): return datetime.datetime.now().strftime(format_string)Library.simple_tag(takes_context=True) takes_context=True参数可以让我们访问模板的当前环境上下文,即将当前环境上下文中的参数和值作为字典传入函数中的一个名为context的参数
@register.simple_tag(takes_context=True)def current_time(context, format_string): timezone = context['timezone'] return your_get_current_time_method(timezone, format_string)当使用take_context=True时,函数的第一个参数必需为context。也可以使用name参数对函数进行重命名。
二 内含标签
这种类型的标签可以被其他模板进行渲染,然后将渲染结果输出
Library.inclusion_tag()支持take_context=True,用法类似Library.simple_tag()
from django import templateregister = template.Library()@register.inclusion_tag('result.html')def test(): a=['first','second','third'] return {'choices':a}result.html 内容
<ul>{% for choice in choices %} <li> {{ choice }} </li>{% endfor %}</ul>test.html内容
{% load mytags %}<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>Title</title></head><body>{% test %}</body></html>view函数:
def test(request): return render(request,'test.html')当访问http://127.0.0.1:8000/test/时,浏览器显示:
三 分配标签
类似于简单标签,但并不会输出结果,可以使用 as 关键字将结果赋给一个参数。
@register.assignment_tagdef get_current_time(format_string): return datetime.datetime.now().strftime(format_string){% get_current_time "%Y-%m-%d %I:%M %p" as the_time %}<p>The time is {{ the_time }}.</p>以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
自定义模版过滤器虽然DTL给我们内置了许多好用的过滤器。但是有些时候还是不能满足我们的需求。因此Django给我们提供了一个接口,可以让我们自定义过滤器,实现自
前言本文主要给大家介绍了关于Django自定义过滤器的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍:过滤器与函数django过滤器的本
vue2.0里,不再有自带的过滤器,需要自己定义过滤器。定义的方法如下:注册一个自定义过滤器,它接收两个参数:过滤器ID和过滤器函数。Vue.filter('f
vue2.0里,不再有自带的过滤器,需要自己定义过滤器。定义的方法如下:注册一个自定义过滤器,它接收两个参数:过滤器ID和过滤器函数。Vue.filter('f
基础类似于自定义指令,可以用全局方法Vue.filter()注册一个自定义过滤器,它接收两个参数:过滤器ID和过滤器函数。过滤器函数以值为参数,返回转换后的值: