---恢复内容开始---
第一步:确保setting中的INSTALL_APPS配置当前的app,要不然Django无法找到自定义的simple_tag.
第二步:在app中创建templatetags模块(模块名只能是templatetags)
第三步:创建任意的.py文件 比如:my_tags.py
from django import template
from django.utils.safestring import mark_safe
register = template.Library() #register的名字是固定的,不可改变
@register.filter
def filter_multi(v1,v2): #过滤器只能接受两个参数,并且可以写在for循环和if条件判断里面
return v1 * v2
@register.simple_tag #和自定义filter类似,只不过接受更灵活的参数,没有个数限制
def simple_tag_multi(v1,v2,v3):
return v1+v2+v3
第四步:在使用自定义的simple_tag和filter文件中导入之前创建的my_tags.py {% load my_tags %}
第五步:如何使用simple_tag和filter(如何调用)
-------------------------------.html
{% load xxx %}
# num=12
{{ num|filter_multi:2 }} #24
{{ num|filter_multi:"[22,333,4444]" }}
{% simple_tag_multi 2 5 %} 参数不限,但不能放在if for语句中
{% simple_tag_multi num 5 %}
注意:filter可以用在if和for等语句后边,simple_tag不可以
{% if num|filter_multi:30 > 100%}
{{ num|filter_multi:30 }}
{% endif %}
inclusion_tag
多用于返回html代码片段
示例:
templatetags/my_inclusion.py
from django import template
register = template.Library()
@register.inclusion_tag(‘result.html‘) #将result.html里面的内容用下面函数的返回值渲染,然后作为一个组件一样,加载到使用这个函数的html文件里面
def show_results(n): #参数可以传多个进来
n = 1 if n < 1 else int(n)
data = ["第{}项".format(i) for i in range(1, n+1)]
return {"data": data}#这里可以穿多个值,和render的感觉是一样的{‘data1‘:data1,‘data2‘:data2....}
result.html
<ul>
{% for choice in data %}
<li>{{ choice }}</li>
{% endfor %}
</ul>
index.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="x-ua-compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>inclusion_tag test</title>
</head>
<body>
{% load inclusion_tag_test %}
{% show_results 10 %}
</body>
</html>
---恢复内容结束---
原文:https://www.cnblogs.com/a2534786642/p/10492154.html