搞定 Django 模板内置标签!

mac2022-06-30  78

作者 | 单雨

责编 | 胡巍巍

出品 | 程序人生(ID:coder_life)

1.debug

概述 :

输出整体的调试信息,包括当前上下文和导入的模块。示例:

django{% for o in list %}    <div class="{% cycle 'row_blue' 'row_green' as rowcolor silent %}"></div>    {% debug %}{% endfor %}

这个标签会输出非常多的信息,通常只有前几行是有用的,如图:

2.filter 

概述 :

对包含在其中的内容进行过滤。用法:

django{% filter force_escape %}   {需要转义的内容}{% endfilter %}

传入参数:

filter标签可以传入参数,比如上述的force_escape(强制转义),可以传入多个参数,参数之间通过“|”进行分隔:

django{% filter force_escape|upper %}   {需要转义的内容}{% endfilter %}

传入参数`{“myname”:"jack"}`渲染效果:

小写字母经过过滤变成了大写。 

3. firstof 

概述 :

输出第一个不是False,不是空值或数字0的值,如果所有的值都是False,空值或者数字0就什么都不输出。使用示例:

django{% firstof a1 a2 a3 a4 a5 a6 %}

传入参数:

`python{        "myname""jack",        "a1"False,        "a2"0,        "a3""",        "a4"True,        "a5"1,        "a6""a6"}

渲染效果:

 

可见第一个不是False的变量是a4。 

返回默认字符串 :

firstof标签也可以设置一个在所有值都是False的情况下返回的字符串。示例:

django{% firstof a1 a2 a3 "所有值都是空值" %}

渲染效果:

 

关闭HTML转义:

默认情况下,输出的变量内容和这个返回的字符串会自动进行HTML转义,如果想要显示一些特别的提示效果,比如红色的警告信息,可以这样:

django{% autoescape off %}    {% firstof a1 a2 a3  "<span style='color:red;'>所有值都是空值<span>" %}{% endautoescape %}

渲染效果:

这样所有的输出的变量和返回的默认字符串都不会进行自动HTML转义。 

如果只想其中的一些变量或者默认字符串不被转义,可以使用safe过滤器。示例:

django    {% firstof a1|safe a2 a3  "<span style='color:red;'>所有值都是空值<span>"|safe %}

只有a1和默认字符串不会被转义。

假如`"a1":"<script type='txt\javascript'>alert('我是a1,我是第一个不是False的值')</script>""`渲染效果:

 

可以看到变量a1没有执行HTML转义,被当做HTML代码执行了。 

输出保存到变量:

firstof标签的输出也可以存储在一个变量中,用法: 

django{% firstof a1 a2 a3  as not_false_value %}{{  not_false_value }}

渲染效果:

4.for 

概述:

循环数组中的每个项,使该项在上下文变量中可用。例如展示一个列表:

django<ul>{% for city in city_list %}    <li>{{ city }}</li>{% endfor %}</ul>

传入参数`{"city_list":['北京','上海','哈尔滨','沈阳'']}`,渲染效果:

倒序渲染:

django<ul>{% for city in city_list reversed %}    <li>{{ city }}</li>{% endfor %}</ul>

效果:

 

渲染嵌套列表:

如果需要渲染嵌套列表,可以把子列表的项解压为单独的变量,比如渲染两只球队人员名单,每队有三个成员:

django{% for member1,member2,member3 in team_list %}    <li>        {{ member1 }},{{ member2 }},{{ member3 }}    </li>{% endfor %}

传入参数`"team_list": [["乔丹", "詹姆斯", "哈登"], ["达尼尔", "杰斯", "本杰明"]]`,

渲染效果: 

渲染字典:

for标签也可以渲染字典,比如渲染产品价格信息:

django{% for product, price in data.items %}    <li>{{ product }}: {{ price }}</li>{% endfor %}

注意: 对于点操作符,字典键查找优先于方法查找。 如果渲染的字典中包含一个名为“items”的键,则为products.items将返回products['items'],而不是products.items。 如果希望在模板中使用字典方法(项、值、键等),应该避免使用类似字典方法的键。  

for标签内置变量:

for标签内置变量的用法和普通变量一样。 

- forloop.counter:当前迭代项的索引,从1开始。

django  {% for product, price in products.items %}      <li>{{ product }}: {{ price }}</li>      {{ forloop.counter}}{替换这个变量得到后面例子的渲染效果}  {% endfor %}

- forloop.counter0:当前迭代项的索引,从0开始。

- forloop.revcounter:从循环项的末尾开始索引到1。 

- forloop.revcounter0:从循环项的末尾开始索引到0。

- forloop.first:如果是第一经过循环,则为True。 

- forloop.last: 如果是最后一次经过循环,则为True。  

- forloop.parentloop:在嵌套循环中,获取当前循环的父循环。forloop.parentloop还可以用点表示法引用内置循环变量,比如:forloop.parentloop.counter、forloop.parentloop.revcounter、forloop.first。效果示例: 

使用forloop.parentloop.counter父循环的当前索引。

django  {% for value in categorys.values %}      {% for k, v in value.items %}          <li>{{ k }}: {{ v }}</li>          {{ forloop.parentloop.counter}}      {% endfor %}  {% endfor %}

传入参数:`"categorys": {"products": {"car": "¥300000", "engine": "¥200000", "tyre": "¥2000"},"sales_volume":{"car":1000,"engine":500,"tyre":20000}, }`

渲染效果:

5.for...empty 

概述:

for标签可以使用一个可选的{% empty %}子句,如果给定数组为空或无法找到,则显示该子句的文本。用法:

django{% for product,price in products.items %}    <li>{{product}}:{{price}}</li>{% empty %}    <li>产品列表为空</li>{% endfor %}

传入参数:`"products": {}` 

渲染效果:

 相当于使用一个if-else判断:

django{% if products %}    {% for product,price in products.items %}        <li>{{product}}:{{price}}</li>    {% endfor %}  {% else %}    <li>产品列表为空</li>  {% endif %}

作者简介:单雨,90 后工科男,伪文艺青年。目前就读于北京理工大学宇航系,喜欢研究 AI,网络爬虫,微信小程序以及机器人,痴迷于 Coding,睡前必撸码。

 热 文 推 荐  ☞ ☞ ☞

点击阅读原文,即刻阅读《程序员大本营》。

你点的每个“在看”,我都认真当成了喜欢
最新回复(0)