if 标签
if标签类似Python中的if语句,同样也有elif和else。但其需要用标签符号 {% if %}
进行包裹。
if标签中可以使用 ==、!=、<、<=、>、>=、in、not in、is、is not
等判断运算符。
# views文件
def age(request):
return render(request, 'age.html', context={'age': 20})
# htlm模板文件
{% if age > 18 %}
<p>您是成年人了</p>
{% elif age == 18 %}
<p>您刚满18岁</p>
{% else %}
<p>您是未成年人</p>
{% endif %}
for 标签
for…in…类似于Python中的for…in…,同样可以遍历列表、元组、字符串、字典等一切可以遍历的对象。
<p>我们的成员有:</p>
{% for person in persons %}
<p>{{ person }}</p>
{% endfor %}
# 逆序遍历 reversed
<p>我们的成员有:</p>
{% for person in persons reversed %}
<p>{{ person }}</p>
{% endfor %}
遍历字典时,需要使用items、keys和values等方法。在DTL中,执行一个方法不能使用圆括号的形式。
{% for key,value in person.items %}
<p>key:{{ key }}</p>
<p>value:{{ value }}</p>
{% endfor %}
在for循环中,DTL提供了一些变量可供使用。
- forloop.counter:当前循环的下标。以1作为起始值。
- forloop.counter0:当前循环的下标。以0作为起始值。
- forloop.revcounter:
- 当前循环的反向下标值。
- 如列表有5个元素,第一次遍历这个属性是等于5,第二次是4,以此类推。
- 以1作为最后一个元素的下标。
- forloop.revcounter0:类似于forloop.revcounter。不同的是最后一个元素的下标是0。
- forloop.first:是否是第一次遍历,返回布尔值。
- forloop.last:是否是最后一次遍历,返回布尔值。
- forloop.parentloop:如果有多个循环嵌套,那么这个属性代表的是上一级的for循环。
{% for person in persons %}
<p>序号:{{ forloop.revcounter0 }}</p>
<p>序号:{{ forloop.last }}</p>
<p>名字:{{ person }}</p>
{% endfor %}
for…in…empty
这个标签使用跟for…in…是一样的,只有当在遍历的对象里,如果没有元素的情况下,才会执行empty中的内容。
注意:在for标签循环中,break、continue语句无效。{% for person in persons %}
<li>{{ person }}</li>
{% empty %}
暂时还没有任何人
{% endfor %}
url 标签
在模版中,我们经常要写一些url,比如某个a标签中需要定义href属性。通过硬编码的方式直接将这个url写死不便于维护,因此建议使用反转的方式来实现,类似于django中的reverse一样。
```python “””urls文件”””app_name = ‘p’
urlpatterns = [
path(‘guys/‘, views.guys, name=’guys’),
path(‘age/
“””html模板文件””” {# guys为url的名字 #} 人员列表 {# p为应用命名空间,age为url的名字 #} 查看年龄
<a name="Dlk8Q"></a>
### url传递参数
如果url反转时需要传递参数,那么可以在后面传递。传递的参数分位置参数和关键字参数,且位置参数和关键字参数不能同时使用。<br />
```python
# urls文件的path部分
path('detail/<book_id>/', views.book_detail, name='detail')
# url反转,使用位置参数
<a href="{% url 'book:detail' 1 %}">图书详情页面</a>
# url反转,使用关键字参数
<a href="{% url 'book:detail' book_id=1 %}">图书详情页面</a>
如果想要在使用url标签反转时,要传递查询字符串的参数,那么必须要手动在后面添加。
<a href="{% url 'book:detail' book_id=1 %}?page=1">图书详情页面</a>
如果需要传递多个参数,可通过空格的方式进行分隔:
<a href="{% url 'book:detail' 1 2 %}">图书详情页面</a>
<a href="{% url 'book:detail' book_id=1 page=2 %}">图书详情页面</a>
with 标签
可给常用变量设置别名:
<h2>{{ persons.0 }}</h2>
{% with persons.0 as p %}
{{ p }}
{% endwith %}
# 上述的p表示persons.0
autoescape 标签
通过该标签,可以进行关闭自动转义:
# 如果不关闭自动转义,会直接输出为字符串
'info': '<a href="https://www.baidu.com">百度</a>'
{# 直接输出字符串#}
{{ info}}
{# 关闭自动转义 #}
{% autoescape off %}
<h2>{{ info }}</h2>
{% endautoescape %}
更多标签:https://docs.djangoproject.com/en/2.0/ref/templates/builtins/