详解django中自定义标签和过滤器


Posted in Python onJuly 03, 2017

想要实现自定义标签和过滤器需要进行准备工作:

准备(必需)工作:

1  在某个app下创建一个名为templatetags(必需,且包名不可变)的包。假设我们在名为polls的app下创建了一个templatetags的包,并在该包下创建了一个名为mytags的文件。那么目录结构看起来应该就像这样:

polls/
  __init__.py
  models.py
  templatetags/
    __init__.py
    mytags.py
  views.py

2  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 template

register = 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 value

2  register该函数

# 登记
register.filter('truncate_chars',truncate_chars)
def truncate_chars(value):
  if value.__len__() > 30:
    return '%s......'% value[0:30]
  else:
    return value

Library.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.filter
def truncate_chars(value):
  if value.__len__() > 30:
    return '%s......'% value[0:30]
  else:
    return value

3  测试模板文件内容

{% load mytags %}
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Title</title>
</head>
<body>
{{ 'alskdjasdfasdfasdffasdfasdfasdffasdffasdffasdffasdfasdffasdffalskdjasdfasdfasdffasdfasdfasdffasdffasdffasdffasdfasdffasdff'|truncate_chars }}
</body>
</html>

4  浏览器显示结果

详解django中自定义标签和过滤器

自定义标签

自定义标签相对于自定义过滤器来说要复杂很多,因为自定义标签可以做任何事情!

自定义标签分为很多类型

1  简单标签  Simple tags

2  内含标签  Inclusion tags

3  分配标签  Assignment tags

一  简单标签

import datetime
from django import template

register = template.Library()

@register.simple_tag
def 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 template
register = 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/时,浏览器显示:

详解django中自定义标签和过滤器 

三  分配标签

类似于简单标签,但并不会输出结果,可以使用 as 关键字将结果赋给一个参数。

@register.assignment_tag
def 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>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python实现远程调用MetaSploit的方法
Aug 22 Python
python错误处理详解
Sep 28 Python
python创建列表并给列表赋初始值的方法
Jul 28 Python
asyncio 的 coroutine对象 与 Future对象使用指南
Sep 11 Python
Python文件与文件夹常见基本操作总结
Sep 19 Python
python3使用scrapy生成csv文件代码示例
Dec 28 Python
Python操作rabbitMQ的示例代码
Mar 19 Python
Python爬取破解无线网络wifi密码过程解析
Sep 17 Python
使用Fabric自动化部署Django项目的实现
Sep 27 Python
Pycharm-community-2020.2.3 社区版安装教程图文详解
Dec 08 Python
matplotlib grid()设置网格线外观的实现
Feb 22 Python
Python可视化神器pyecharts绘制水球图
Jul 07 Python
pygame实现弹力球及其变速效果
Jul 03 #Python
[原创]使用豆瓣提供的国内pypi源
Jul 02 #Python
python中安装Scrapy模块依赖包汇总
Jul 02 #Python
Python使用filetype精确判断文件类型
Jul 02 #Python
使用python实现tcp自动重连
Jul 02 #Python
详解python3中socket套接字的编码问题解决
Jul 01 #Python
详解Python中for循环是如何工作的
Jun 30 #Python
You might like
十天学会php之第六天
2006/10/09 PHP
php中filter_input函数用法分析
2014/11/15 PHP
Zend Framework实现将session存储在memcache中的方法
2016/03/22 PHP
PHP自动生成缩略图函数的源码示例
2019/03/18 PHP
在jQuery 1.5中使用deferred对象的代码(翻译)
2011/03/10 Javascript
capacityFixed 基于jquery的类似于新浪微博新消息提示的定位框
2011/05/24 Javascript
关于js中alert弹出窗口文本换行问题简单详细说明
2012/12/11 Javascript
js中的异常处理try...catch使用介绍
2013/09/21 Javascript
json字符串之间的相互转换示例代码
2014/08/21 Javascript
JavaScript获取指定元素位置的方法
2015/04/08 Javascript
深入分析下javascript中的[]()+!
2015/07/07 Javascript
jQuery自制提示框tooltip改进版
2016/08/01 Javascript
bootstrap table实现iview固定列的效果实例代码详解
2019/09/30 Javascript
Weex开发之地图篇的具体使用
2019/10/16 Javascript
JavaScript this关键字指向常用情况解析
2020/09/02 Javascript
vue2.0 watch里面的 deep和immediate用法说明
2020/10/30 Javascript
[07:55]2014DOTA2 TI正赛第三日 VG上演推进荣耀DKEG告别
2014/07/21 DOTA
[00:59]PWL开团时刻DAY7——我在赶
2020/11/06 DOTA
栈和队列数据结构的基本概念及其相关的Python实现
2015/08/24 Python
Python实现针对json中某个关键字段进行排序操作示例
2018/12/25 Python
Python3enumrate和range对比及示例详解
2019/07/13 Python
django中SMTP发送邮件配置详解
2019/07/19 Python
Pytorch中accuracy和loss的计算知识点总结
2019/09/10 Python
python实现从wind导入数据
2019/12/03 Python
PyCharm如何导入python项目的方法
2020/02/06 Python
Python爬虫爬取百度搜索内容代码实例
2020/06/05 Python
如何让Java程序执行效率更高
2014/06/25 面试题
大一学生假期实习的自我评价
2013/10/12 职场文书
技术人员面试提纲
2013/11/28 职场文书
导游个人求职信范文
2014/03/23 职场文书
支部书记四风问题对照检查材料
2014/10/04 职场文书
社区班子个人对照检查材料思想汇报
2014/10/07 职场文书
小班上学期个人总结
2015/02/12 职场文书
导游词之张家界
2019/10/31 职场文书
vue-cropper插件实现图片截取上传组件封装
2021/05/27 Vue.js
Python进程间的通信之语法学习
2022/04/11 Python