Django中利用filter与simple_tag为前端自定义函数的实现方法


Posted in Python onJune 15, 2017

前言

Django的模板引擎提供了一般性的功能函数,通过前端可以实现多数的代码逻辑功能,这里称之为一般性,是因为它仅支持大多数常见情况下的函数功能,例如if判断,ifequal对比返回值等,但是稍微复杂一些的函数功能并不支持,例如通过模板来判断一个返回值是否是合法的数字类型,此时如果又不希望通过后台视图代码来实现的话,我们就可以自定义一些前端函数功能。

Django为我们提供了两种方式,分别是filter和simple_tag,下面对比两种方式,分别实现判断返回值的功能函数。

准备工作

      1、应用程序必须要注册到settings配置文件中

      2、在应用目录下创建templatetags目录

      3、在templatetags创建模块文件,并导入Django内部方法

filter

在templatetags目录下创建python模块,这里命名为app01_func.py,内容如下:

from django import template
from django.template.defaultfilters import stringfilter

register = template.Library()


@register.filter
def value_verification(value): # value为前端传递的参数
 try:
  int(value)
  return True
 except:
  return False

定制完后台功能后,就可以在模板文件中调用函数功能,首选需要在模板文件头中引入后台python模块。

{% load app01_func %}

例如我们需要判断后台返回值load是否为一个有效数字时,可以做如下调用:

{% if load|value_verification %}
 {{ load }} is a valid int number.
{% else %}
 {{ load }} is letter.
{% endif %}

simple_tag

simple_tag的代码方式与filter一样,不同的是在装饰器部分需要调用simple_tag方法

from django import template
from django.template.defaultfilters import stringfilter

register = template.Library()


@register.simple # 这里修改为simple_tag
def value_verification(value): # value为前端传递的参数
 try:
  int(value)
  return True
 except:
  return False

同时前端的调用方式也需要改为

{% value_verification load %}

传递参数

      - filter 最多支持两个参数传递

      - simple 支持多个参数传递

filter中可以通过下面的方式实现参数传递

{{ load | value_verification:"100"}}

这里即向后端传递了两个参数,一个是load,另一个是100,后端也要为函数指定好形参:

def value_verification(value, custom): # 配置好形参
 ...

simple_tag中可以指定多个形参,前台的调用方式如下:

{% value_verification load 100 200 ... %}

这里filter中最多只能接受两个参数,但此时参数又多,又不想使用simple_tag的情况下,可以将多个参数用特定字符拼接成一个字符串传递给后端,后端通过split方式同样能获取多个参数。

对比总结

通过simple_tag和filter可以完成模板引擎无法完成的某些事情,filter将我们指定的函数变成了返回值可执行的方法,simple_tag将函数功能变为标签功能,例如if、ifequal等,同样调用方式也不同,对比如下:

{{ load | value_verification }} # filter
{% value_verification load %} # simple_tag

因为调用方式的不同,如果返回值需要做为if或ifequal判断依据的话,这里只能使用filter方法了,stringfilter方法可以实现将接收到的所有参数变为字符串类型,同register装饰器一样引用到函数方法上即可,这里注意要放在register下面,否则无法生效。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Python 相关文章推荐
Python中使用tarfile压缩、解压tar归档文件示例
Apr 05 Python
使用Python向DataFrame中指定位置添加一列或多列的方法
Jan 29 Python
Python3利用Dlib实现摄像头实时人脸检测和平铺显示示例
Feb 21 Python
用Python写一个模拟qq聊天小程序的代码实例
Mar 06 Python
Django+zTree构建组织架构树的方法
Aug 21 Python
如何在 Django 模板中输出 "{{"
Jan 24 Python
谈一谈数组拼接tf.concat()和np.concatenate()的区别
Feb 07 Python
五分钟带你搞懂python 迭代器与生成器
Aug 30 Python
python speech模块的使用方法
Sep 09 Python
Python list和str互转的实现示例
Nov 16 Python
如何设置PyCharm中的Python代码模版(推荐)
Nov 20 Python
Python基础 括号()[]{}的详解
Nov 07 Python
Python中关于Sequence切片的下标问题详解
Jun 15 #Python
解决python3在anaconda下安装caffe失败的问题
Jun 15 #Python
带你了解python装饰器
Jun 15 #Python
解决Linux系统中python matplotlib画图的中文显示问题
Jun 15 #Python
Python之os操作方法(详解)
Jun 15 #Python
基于Linux系统中python matplotlib画图的中文显示问题的解决方法
Jun 15 #Python
Python使用QRCode模块生成二维码实例详解
Jun 14 #Python
You might like
php线性表顺序存储实现代码(增删查改)
2012/02/16 PHP
PHP自定义大小验证码的方法详解
2013/06/07 PHP
php初始化对象和析构函数的简单实例
2014/03/11 PHP
PHP jpgraph库的配置及生成统计图表:折线图、柱状图、饼状图
2017/05/15 PHP
解决laravel 表单提交-POST 异常的问题
2019/10/15 PHP
10个新的最有前途的JavaScript框架
2009/03/12 Javascript
JS 文字符串转换unicode编码函数
2009/05/30 Javascript
JavaScript 加号(+)运算符号
2009/12/06 Javascript
YUI的Tab切换实现代码
2010/04/11 Javascript
关于jQuery参考实例 1.0 jQuery的哲学
2013/04/07 Javascript
javascript鼠标右键菜单自定义效果
2020/12/08 Javascript
你一定会收藏的Nodejs代码片段
2016/02/04 NodeJs
通过JS和PHP两种方法判断用户请求时使用的浏览器类型
2016/09/01 Javascript
详解Node.js开发中的express-session
2017/05/19 Javascript
react-router中的属性详解
2017/06/01 Javascript
JS实现十字坐标跟随鼠标效果
2017/12/25 Javascript
浅谈vue项目可以从哪些方面进行优化
2018/05/05 Javascript
基于Vue2-Calendar改进的日历组件(含中文使用说明)
2019/04/14 Javascript
vue-cli项目使用mock数据的方法(借助express)
2019/04/15 Javascript
ECharts地图绘制和钻取简易接口详解
2019/07/12 Javascript
js实现简易点击切换显示或隐藏
2020/11/29 Javascript
python实现多线程暴力破解登陆路由器功能代码分享
2015/01/04 Python
python下paramiko模块实现ssh连接登录Linux服务器
2015/06/03 Python
TensorFlow高效读取数据的方法示例
2018/02/06 Python
python 爬虫 批量获取代理ip的实例代码
2018/05/22 Python
PyCharm 2019.3发布增加了新功能一览
2019/12/08 Python
win7上tensorflow2.2.0安装成功 引用DLL load failed时找不到指定模块 tensorflow has no attribute xxx 解决方法
2020/05/20 Python
CSS3 优势以及网页设计师如何使用CSS3技术
2009/07/29 HTML / CSS
世界上最好的帽子:Tilley
2016/11/27 全球购物
PHP如何去执行一个SQL语句
2016/03/05 面试题
医院护士的求职信范文
2013/12/26 职场文书
爱耳日宣传活动总结
2014/07/05 职场文书
法律专业大学生职业生涯规划书:向目标一步步迈进
2014/09/22 职场文书
2014年质检工作总结
2014/11/26 职场文书
大学生自荐书范文
2015/03/05 职场文书
python blinker 信号库
2022/05/04 Python