定义simple_tag步骤
一、创建templatetags文件
首先在app下创建templatetags文件;名字不许叫这个,不能改变。
二、在文件中创建一个py文件
文件名自定义
三、在创建的文件中写具体的方法
注意点:
1、必须引入指定的模块
from django import template from django.utils.safestring import mark_safe
2、创建一个对象register
register = template.Library()
注意:
名字必须叫这个register
,不能更改。
3、写具体的方式的时候加上装饰器
装饰器的名字:
@register.simple_tag
4、数据返回
方法写完要将具体的数据通过retunr
返回。
5、特别 mark_safe()
上面图片中我们看到返回数据的时候加了和mark_safe()方法。
说明:
正常我们返回的是字符串,直接显示在页面上也是字符串
。如果我们想返回一些
标签
,标签相对浏览器来说,的有渲染效果,那么我们就必须通过mark_safe()
方法将要返回的数据进行转化,然后返回后,标签就具有本身的效果。
四、前台页面的使用
1、首先在前台页面要导入文件
{% load 文件名 %}
2、使用
规则:
{% 方法名 参数1 参数2 %}
注意:
1、可以接收多个参数,用空格
隔开。
2、这个定义的模板语言不能和判断语言
组合,不然执行不了。
定义filter步骤
filter
自定义模板的步骤和simple_tags
的步骤是一样的,可以参考前面。
区别
filter和simple_tags的区别:
1、装饰器不一样
filter:
@register.filter
2、定义的方法接收的参数不一样
simple_tags
定义的方法能接收多个参数
。filter
定义的方法最多只能接收2个参数
。
3、使用不同
filter的规则:
{% 参数1|方法:"参数2" %}
说明:
filter定义的方法可以和判断语和在一起使用。
filter定义的方法还可以直接通过双花”{{ }}“括号使用。
filter定义的方法要想接收多个数据,只能将数据作通过指定的符号
组合成字符串
,然后传入,再在方法中通过符号进行分割
来获取。