django基础篇04-自定义simple_tag和fitler
自定义simple_tag
- app目录下创建templatetags目录
- templatetags目录下创建xxpp.py
- 创建template对象register,注意变量名必须为register
- @register.simple_tag
def func(arg1,arg2):
pass - settings.py文件中注册app,INSTALLED_APPS = ['app']
- 模版文件顶部{% load xxoo %}
- {{ 函数名 参数一 参数二}}
django如何传递参数给template对象的?
没错,就是通过views.py的函数传递,例如 render(request,'xxx.html',{'xx':'oo'}),还有其他的方式吗?其实还有url的方式传递参数,这里不再赘述
今天,我们讲解一下template对象,如何与py进行交互,这里的py是指单独的py文件,而不是基于django的py文件
下面看一段简单的代码
首先,我们在app01文件夹下创建一个templatetags目录,然后在创建xxoo.py
from django import template
from django.utils.safestring import mark_safe register = template.Library() @register.simple_tag
def simple_01():
return 'Python'
xxoo.py
然后模板文件index.html
{% load xxoo %}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<div>
{% simple_01 %}
</div>
</body>
</html>
index.html
注意:自定义simple_tag的4个注意事项
1、在模版文件中 {% load py文件 %}
2、settings.py文件中,注册app,本文自创建app01,所以在INSTALLED_APPS = ['app01']
3、在app01目录下创建目录templatetags,注意必须在app01目录下
4、创建template对象时,变量名固定,必须register,必须为register,必须为register
5、必须重启服务
接下来神奇的事情发生了
进阶
在之前基础上,我们加上参数
from django import template
from django.utils.safestring import mark_safe register = template.Library() @register.simple_tag
def simple_02(a,b):
return a + b
xxoo.py
{% load xxoo %}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<div>
{% simple_02 1 2 %}
</div>
</body>
</html>
index.html
自定义filter
- app目录下创建templatetags目录
- templatetags目录下创建xxoo.py文件
- 创建template的register对象,注意变量名必须为register
- @register.filter
def func(arg1,arg2):
pass - settings.py中注册app,INSTALLED_APPS = ['app']
- 模版文件顶部{% load xxoo %}
- {{ 参数一|函数名:'参数二,参数三'}} {{ 参数一|函数名:参数二 }},注意:函数名和参数二之间不能有空格
from django import template
from django.utils.safestring import mark_safe register = template.Library() @register.filter
def simple_03(a,b):
return a +'-'+ b
xxoo.py
{% load xxoo %}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<div>
{{ '张杰'|simple_03:'谢娜' }}
</div>
</body>
</html>
index.html
自定义simple_tag和filter的优缺点
simple_tag
优点:可以传多个参数
缺点:不能作为if语句的条件
filter
优点:可以作为if语句的条件
缺点:参数最多只能传2个,而且不能有空格,其他的只能通过字符串拼接,然后在分割
django基础篇04-自定义simple_tag和fitler的更多相关文章
- 01: Django基础篇
目录:Django其他篇 01:Django基础篇 02:Django进阶篇 03:Django数据库操作--->Model 04: Form 验证用户数据 & 生成html 05:Mo ...
- iOS系列 基础篇 04 探究视图生命周期
iOS系列 基础篇 04 探究视图生命周期 视图是应用的一个重要的组成部份,功能的实现与其息息相关,而视图控制器控制着视图,其重要性在整个应用中不言而喻. 以视图的四种状态为基础,我们来系统了解一下视 ...
- Web框架django基础篇
基本配置及学习 路由(Urls).视图(Views).模板(Template).Model(ORM). 简介 Django 是一个由 Python 写成的开放源代码的 Web 应用框架.它最初是被开 ...
- python 之 Django 基础篇
1,Django流程介绍 MTV模式 著名的MVC模式:所谓MVC就是把web应用分为模型(M),控制器(C),视图(V)三层:他们之间以一种插件似的,松耦合的方式连接在一起. 模型负责业务对象与数据 ...
- django基础篇
Python的WEB框架有Django.Tornado.Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了ORM.模型绑定.模板引擎.缓存.Session等诸多功能. ...
- Java多线程系列--“基础篇”04之 synchronized关键字
概要 本章,会对synchronized关键字进行介绍.涉及到的内容包括:1. synchronized原理2. synchronized基本规则3. synchronized方法 和 synchro ...
- Python学习-day19 django基础篇
Python的WEB框架有Django.Tornado.Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了ORM.模型绑定.模板引擎.缓存.Session等诸多功能. ...
- 01:django基础篇
Django其他篇 目录: 1.1 django初探 1.2 第一个django项目 1.3 django render/redirect/HttpResponse 和 request.GET req ...
- python的django基础篇
一.Django基础 Django 是用Python开发的一个免费开源的Web框架,可以用于快速搭建高性能,优雅的网站! Django的特点: 强大的数据库功能:拥有强大的数据库操作接口(QueryS ...
随机推荐
- Bootstrap Table 的X-editable插件怎么用
在准备使用X-editable来做Bootstrap Table 的行内编辑的时候,根据http://www.cnblogs.com/landea... 的文章,我不能将全部效果重复实现,网上也搜索了 ...
- linux grep 正则
grep : 显示匹配行 -v: 反显示 -e 使用扩展正则表达式 黑色字体表明是原生正则表达式 红色字体表明是扩张正则表达式 1.匹配操作符 \: 转义字符串(正则使用扩展字符操作 没有使用-e ...
- libusb获取usb设备的idVendor(vid),idProduct(pid),以及Serial Number
发表于2015/6/23 21:55:11 4594人阅读 最近在做关于usb设备的项目,用到了libusb,发现关于这个的函数库的介绍,讲解很少,下面仅仅是简单展示一些基本的使用方法,以备后用. ...
- linux 设置 hugepage
临时设置 hugepage > /sys/kernel/mm/hugepages/hugepages-16384kB/nr_hugepages 查看是否设置成功 cat /proc/meminf ...
- collection:指定要遍历的集合
//查询员工id'在给定集合中(1,6)的 public List<Employee> getEmpsByConditionForeach(@Param("ids")L ...
- JS 替换所有的空格
在JS中替换掉输入框内的空格,是在处理表单需求的时候极为常用的一项操作,以防止用户的操作习惯引起数据异常,保证传参的安全性. NO.1 name.replace(" "," ...
- 在VSCode中开启ESLint风格审查
最近一直在学习开发一个VUE项目,几乎没有前端基础摸爬滚打,就一边摸索HTML,JS,CSS一边模仿着已有代码开发,也还算能学到东西. VSCode确实还不错,很轻量.在刚开始学写vue的时候,后台总 ...
- python 接口测试时,后端报错no String-argument constructor/factory method
解决方法: 1.先将字典转化为序列化的数据类型 data = {"pageNo":0,"pageSize":10,"shopId":15,& ...
- ArchLinux下XFCE的一个问题修复:thunar加载的环境变量不正确
家里的电脑上,安装了Arch32与Arch64.不记得以前做过什么操作, 导致在Arch32下,Thunar启动后,其环境变量缺失很多内容. 主要在PATH及LD_LIBRARY_PATH几个关键变量 ...
- ES6标准入门 第五章:数值的扩展
1.二进制和八进制数值表示法 二进制前缀:0b(或0B): 八进制前缀:0o(或0O). 注意:ES5的严格模式 和 ES6中不再允许使用 0 表示八进制. 将二进制和八进制数值转换为十进制数值 ...