# 第三节:常用标签
# 常用的模板标签:
1. `if`标签:`if`标签相当于`Python`中的`if`语句,有`elif`和`else`相对应,但是所有的标签都需要用标签符号(`{%%}`)进行包裹。`if`标签中可以使用`==、!=、<、<=、>、>=、in、not in、is、is not`等判断运算符。示例代码如下:
```
<pre class="calibre12">```
{% if "张三" in persons %}
<p>张三</p>
{% else %}
<p>李四</p>
{% endif %}
```
```
2. `for...in...`标签:`for...in...`类似于`Python`中的`for...in...`。可以遍历列表、元组、字符串、字典等一切可以遍历的对象。示例代码如下:
```
<pre class="calibre12">```
{% for person in persons %}
<p>{{ person.name }}</p>
{% endfor %}
```
```
如果想要反向遍历,那么在遍历的时候就加上一个`reversed`。示例代码如下:
```
<pre class="calibre12">```
{% for person in persons reversed %}
<p>{{ person.name }}</p>
{% endfor %}
```
```
遍历字典的时候,需要使用`items`、`keys`和`values`等方法。在`DTL`中,执行一个方法不能使用圆括号的形式。遍历字典示例代码如下:
```
<pre class="calibre12">```
{% 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循环。
3. `for...in...empty`标签:这个标签使用跟`for...in...`是一样的,只不过是在遍历的对象如果没有元素的情况下,会执行`empty`中的内容。示例代码如下:
```
<pre class="calibre12">```
{% for person in persons %}
<li>{{ person }}</li>
{% empty %}
暂时还没有任何人
{% endfor %}
```
```
4. `with`标签:在模版中定义变量。有时候一个变量访问的时候比较复杂,那么可以先把这个复杂的变量缓存到一个变量上,以后就可以直接使用这个变量就可以了。示例代码如下:
```
<pre class="calibre12">```
context = {
"persons": ["张三","李四"]
}
{% with lisi=persons.1 %}
<p>{{ lisi }}</p>
{% endwith %}
```
```
有几点需要强烈的注意:
- 在`with`语句中定义的变量,只能在`{%with%}{%endwith%}`中使用,不能在这个标签外面使用。
- 定义变量的时候,不能在等号左右两边留有空格。比如`{% with lisi = persons.1%}`是错误的。
- 还有另外一种写法同样也是支持的:```
<pre class="calibre12">```
{% with persons.1 as lisi %}
<p>{{ lisi }}</p>
{% endwith %}
```
```
5. `url`标签:在模版中,我们经常要写一些`url`,比如某个`a`标签中需要定义`href`属性。当然如果通过硬编码的方式直接将这个`url`写死在里面也是可以的。但是这样对于以后项目维护可能不是一件好事。因此建议使用这种反转的方式来实现,类似于`django`中的`reverse`一样。示例代码如下:
```
<pre class="calibre12">```
<a href="{% url 'book:list' %}">图书列表页面</a>
```
```
如果`url`反转的时候需要传递参数,那么可以在后面传递。但是参数分位置参数和关键字参数。位置参数和关键字参数不能同时使用。示例代码如下:
```
<pre class="calibre12">```
# 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`标签反转的时候要传递查询字符串的参数,那么必须要手动在在后面添加。示例代码如下:
```
<pre class="calibre12">```
<a href="{% url 'book:detail' book_id=1 %}?page=1">图书详情页面</a>
```
```
如果需要传递多个参数,那么通过空格的方式进行分隔。示例代码如下:
```
<pre class="calibre12">```
<a href="{% url 'book:detail' book_id=1 page=2 %}">图书详情页面</a>
```
```
6. `spaceless`标签:移除html标签中的空白字符。包括空格、tab键、换行等。示例代码如下:
```
<pre class="calibre12">```
{% spaceless %}
<p>
<a href="foo/">Foo</a>
</p>
{% endspaceless %}
```
```
那么在渲染完成后,会变成以下的代码:
```
<pre class="calibre12">```
<span class="hljs-tag"><<span class="hljs-class">p</span>></span><span class="hljs-tag"><<span class="hljs-class">a</span> <span class="hljs-class">href</span>=<span class="hljs-string">"foo/"</span>></span>Foo<span class="hljs-tag"></<span class="hljs-class">a</span>></span><span class="hljs-tag"></<span class="hljs-class">p</span>></span>
```
```
`spaceless`只会移除html标签之间的空白字符。而不会移除标签与文本之间的空白字符。看以下代码:
```
<pre class="calibre12">```
{% spaceless %}
<strong>
Hello
</strong>
{% endspaceless %}
```
```
这个将不会移除`strong`中的空白字符。
7. `autoescape`标签:开启和关闭这个标签内元素的自动转义功能。自动转义是可以将一些特殊的字符。比如`<`转义成`html`语法能识别的字符,比如`<`会被转义成`<`,而`>`会被自动转义成`>`。模板中默认是已经开启了自动转义的。`autoescape`的示例代码如下:
```
<pre class="calibre12">```
<span class="hljs-title"># 传递的上下文信息</span>
context = {
<span class="hljs-string">"info"</span>:<span class="hljs-string">"<a href='www.baidu.com'>百度</a>"</span>
}
<span class="hljs-title"># 模板中关闭自动转义</span>
{% autoescape on %}
{{ info }}
{% endautoescape %}
```
```
那么就会显示百度的一个超链接。如果把`on`成`off`,那么就会显示成一个普通的字符串。示例代码如下:
```
<pre class="calibre12">```
{% autoescape on %}
{{ info }}
{% endautoescape %}
```
```
8. `verbatim`标签:默认在`DTL`模板中是会去解析那些特殊字符的。比如`{%`和`%}`以及`{{`等。如果你在某个代码片段中不想使用`DTL`的解析引擎。那么你可以把这个代码片段放在`verbatim`标签中。示例代码下:
```
<pre class="calibre12">```
{% verbatim %}
{{<span class="hljs-keyword">if</span> dying}}Still alive.{{/<span class="hljs-keyword">if</span>}}
{% endverbatim %}
```
```
9. 更多标签请参考官方文档:`https://docs.djangoproject.com/en/2.0/ref/templates/builtins/`
- Introduction
- 第一章:学前准备
- 第一节:虚拟环境
- 第二节:准备工作
- 第三节:Django介绍
- 第四节:URL组成部分
- 第二章:URL与视图
- 第一节:第一个Django项目
- 第二节:视图与URL分发器
- 第三章:模板
- 第一节:模板介绍
- 第二节:模板变量
- 第三节:常用标签
- 第四节:常用过滤器
- 第五节:自定义过滤器
- 第七节:模版结构优化
- 第八节:加载静态文件
- 第四章:数据库
- 第一节:MySQL相关软件
- 第二节:数据库操作
- 第三节:ORM模型
- 第四节:模型常用字段
- 第五节:外键和表关系
- 第六节:增删改查操作
- 第七节:查询操作
- 第八节:QuerySet API
- 第九节:ORM模型迁移
- 第十节:ORM作业
- 第十一节:ORM作业参考答案
- 第十二节:Pycharm连接数据库
- 第五章:视图高级
- 第一节:限制请求method
- 第二节:页面重定向
- 第三节:HttpRequest对象
- 第四节:HttpResponse对象
- 第五节:生成CSV文件
- 第六节:类视图
- 第七节:错误处理
- 第六章:表单
- 第一节:表单概述
- 第二节:用表单验证数据
- 第三节:ModelForm
- 第四节:文件上传
- 第七章:cookie和session
- 第八章:上下文处理器和中间件
- 第一节:上下文处理器
- 第二节:中间件
- 第九章:安全
- 第一节:CSRF攻击
- 第二节:XSS攻击
- 第三节:点击劫持攻击
- 第四节:SQL注入
- 第十章:信号
- 第一节:什么是信号
- 第十一章:验证和授权
- 第一节:概述
- 第二节:用户对象
- 第三节:权限和分组
- 第十二章:Admin系统
- 第十三章:Django的缓存
- 第十四章:memcached
- 第十五章:Redis