pythonのsimple_tag

时间:2023-03-09 17:45:20
pythonのsimple_tag

当我们需要在页面种直接调用py文件中的某些方法时,我们就要用到simple_tag。具体步骤如下:

1.在某个app下创建templatetags文件夹,切记该名称是不可以改变的。

2.在该文件夹下创建任意的.py文件,如test.py,test.py内容如下:

 from django import template

 from django.utils.safestring import mark_safe
# register名称不可以改变
register = template.Library() @register.simple_tag def myCheck(param1,param2):
return param1 + param2

3.在setting中注册该app,如果是系统生成时就添加的,则不需要进行app注册

 INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'app01.apps.App01Config', # 我这里是创建系统时,就直接创建了相关的app01
]

4.在页面中引入(1)顶部引入{%load  test%}  test是我们在templatetags文件夹下创建的.py文件。(2)重点看第10行代码 {% 函数名 arg1 arg2 %}对应的是.py文件中相应函数及其所需要传入的相关参数。并且参数中间是可以添加空格的。

 {% load  test%}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<h1>{{ name }}</h1>
<h1>{% myCheck 3 2 %}</h1>
</body>
</html>

pythonのsimple_tag

 @register.filter
def myCheck1(param1,param2):
return param1 + param2
 <h1>{{ "name:"|myCheck1:"Jerry" }}</h1>

filter和simple_tag优缺点:

1.前者参数最多能有两个,并且参数前边不能有空格,如果前者需要添加多个参数只能<h1>{{ "参数1:"|myCheck1:"参数2" }}</h1>,然后在后台split进行分割。而后者可以有多个参数,并且参数之间可以有空格

2.前者还可以写在页面中的{%if  "参数1:"|myCheck1:"参数2" %}{%endif %}中,这个是后者不可以替代的。