django 内置标签与过滤器

#内置标签与过滤器

本文档介绍了Django的内置模板标签和过滤器。 我们推荐尽可能使用 自动文档,同时也可以自行编辑任何已安装的自定义标签或过滤器的文档。
##内置标记引用
###autoescape

控制自动转义是否可用.这种标签带有任何 on 或 off 作为参数的话,他将决定转义块内效果。该标签会以一个endautoescape作为结束标签.

当自动转义生效时,所有变量内容会被转义成HTML输出(在所有过滤器生效后)这等同与手动将escape筛选器应用于每个变量。

唯一一个例外是,变量或者通过渲染变量的代码,或者因为它已经应用了 safe或escape过滤器,已经被标记为“safe”。

例如:

{% autoescape on %}
    {{ body }}
{% endautoescape %}

###block

block标签可以被子模板覆盖.查看 模板继承 可以获得更多信息.
###comment(注释)

在 {% comment %} 和 {% endcomment %},之间的内容会被忽略,作为注释。在第一个标签可以插入一个可选的记录。 比如,当要注释掉一些代码时,可以用此来记录代码被注释掉的原因。

简单实例:

Rendered text with {{ pub_date|date:"c" }}

{% comment "Optional note" %}

Commented out text with {{ create_date|date:"c" }}

{% endcomment %}

comment标签不能嵌套使用。
###csrf_token

这个标签用于跨站请求伪造保护, 具体可以参考Cross Site Request Forgeries中的描述。
###cycle

每当这个标签被访问,则传出一个它的可迭代参数的元素。第一次访问返回第一个元素,第二次访问返回第二个参数,以此类推.一旦所有的变量都被访问过了,就会回到最开始的地方,重复下去

这个标签在循环中特别有用:

{% for o in some_list %}
    
        ...
    
{% endfor %}

第一次迭代产生的HTML引用了 row1类,第二次则是row2类,第三次 又是row1 类,如此类推。

你也可以使用变量,例如,如果你有两个模版变量, rowvalue1和rowvalue2, 你可以让他们的值像这样替换:

{% for o in some_list %}
    
        ...
    
{% endfor %}

被包含在cycle中的变量将会被转义。你可以禁止自动转义:

{% for o in some_list %}
    
        ...
    
{% endfor %}

你能混合使用变量和字符串:

{% for o in some_list %}
    
        ...
    
{% endfor %}

在某些情况下,您可能需要连续引用一个当前循环的值,而不前进到下一个循环值。要达到这个目的,只需使用“as”来给{% cycle %}一个别名,就像这样:

{% cycle 'row1' 'row2' as rowcolors %}

从那时起(设置别名后),你可以通过将别名作为一个模板变量进行引用,从而随意在模板中插入当前循环的值。如果要将循环值移动到独立于原始cycle标记的下一个值,可以使用另一个cycle标记并指定变量的名称。所以,下面的模板:


    ...
    ...


    ...
    ...

将输出:


    ...
    ...


    ...
    ...

cycle 标签中,通过空格分割,你可以使用任意数量的值。被包含在单引号 (’)或者双引号 (") 中的值被认为是可迭代字符串,相反,没有被引号包围的值被当作模版变量。

默认情况下,当你在cycle标签中使用as 关键字时,关于{% cycle %}的使用,会启动cycle并且直接产生第一个值。如果你想要在嵌套循环中或者included模版中使用这个值,那么将会遇到困难。如果你只是想要声明cycle,但是不产生第一个值,你可以添加一个silent关键字来作为cycle标签的最后一个关键字。例如:

{% for obj in some_list %}
    {% cycle 'row1' 'row2' as rowcolors silent %}
    {% include "subtemplate.html" %}
{% endfor %}

这将输出元素的列表,其中class在row1和row2之间交替。子模板将在其上下文中访问rowcolors,并且该值将匹配包围它的的类。如果省略silent关键字,则row1和row2将作为正常文本发出,

当在循环定义上使用silent关键字时,静默将自动应用于该特定周期标记的所有后续使用。

The following template would output nothing, even though the second call to {% cycle %} doesn’t specify silent:

{% cycle 'row1' 'row2' as rowcolors silent %}
{% cycle rowcolors %}

为了向后兼容,{% cycle %}标记支持来自以前Django版本的劣质旧语法。你不应该在任何新项目中使用它,但是为了仍在使用它的人,这里是它的样子:

{% cycle row1,row2,row3 %}

在这里,每个值都是字符串,并且无法置顶变量名或者直接的逗号或空格。我们提到你不应该在任何新项目中使用这种语法?
###debug

输出整个调试信息,包括当前上下文和导入的模块。
###extends

表示当前模板继承自一个父模板

这个标签可以有两种用法:

    {% extends "base.html" %} (要有引号).继承名为"base.html"的父模板
    {% extends variable %} 使用variable的值. 如果变量被计算成一个字符串,Django将会把它看成是父模版的名字。如果变量被计算到一个Template对象,Django将会使用那个对象作为一个父模版。

###filter

通过一个或多个过滤器对内容过滤。 作为灵活可变的语法,多个过滤器被管道符号相连接,且过滤器可以有参数。

注意块中所有的内容都应该包括在filter 和endfilter 标签中。

简单用例:

{% filter force_escape|lower %}
    This text will be HTML-escaped, and will appear in all lowercase.
{% endfilter %}

注意

escape和safe过滤器不是可接受的参数。而应使用autoescape标记来管理模板代码块的自动转义。
firstof

输出第一个不为False参数。如果传入的所有变量都为False,就什么也不输出。

简单用例:

{% firstof var1 var2 var3 %}

它等价于:

{% if var1 %}
    {{ var1 }}
{% elif var2 %}
    {{ var2 }}
{% elif var3 %}
    {{ var3 }}
{% endif %}

当然你也可以用一个默认字符串作为输出以防传入的所有变量都是False:

{% firstof var1 var2 var3 "fallback value" %}

标签auto-escapes是开启的, 你可以这样关闭auto-escaping:

{% autoescape off %}
    {% firstof var1 var2 var3 "fallback value" %}
{% endautoescape %}

如果只想要部分变量被规避,可以这样使用:

{% firstof var1 var2|safe var3 "fallback value"|safe %}

for

循环组中的每一个项目,并让这些项目在上下文可用。 举个例子,展示athlete_list中的每个成员:

    {% for athlete in athlete_list %}
  • {{ athlete.name }}
  • {% endfor %}

可以利用{% for obj in list reversed %}反向完成循环。

如果你需要循环一个包含列表的列表,可以通过拆分每一个二级列表为一个独立变量来达到目的。 举个例子,如果你的内容包括一个叫做points的(x,y) 列表,你可以像以下例子一样输出points列表:

{% for x, y in points %}
There is a point at {{ x }},{{ y }}
{% endfor %}

如果你想访问一个字典中的项目,这个方法同样有用。举个例子:如果你的内容包含一个叫做data的字典,下面的方式可以输出这个字典的键和值:

{% for key, value in data.items %}
    {{ key }}: {{ value }}
{% endfor %}

The current iteration of the loop (1-indexed)
Variable Description
forloop.counter The current iteration of the loop (1-indexed)
forloop.counter0 The current iteration of the loop (0-indexed)
forloop.revcounter The number of iterations from the end of the loop (1-indexed)
forloop.revcounter0 The number of iterations from the end of the loop (0-indexed)
forloop.first True if this is the first time through the loop
forloop.last True if this is the last time through the loop
forloop.parentloop For nested loops, this is the loop surrounding the current one
for … empty

for 标签带有一个可选的{% empty %} 从句,以便在给出的组是空的或者没有被找到时,可以有所操作。

    {% for athlete in athlete_list %}
  • {{ athlete.name }}
  • {% empty %}
  • Sorry, no athletes in this list.
  • {% endfor %}

它和下面的例子作用相等,但是更简洁、更清晰甚至可能运行起来更快:

    {% if athlete_list %} {% for athlete in athlete_list %}
  • {{ athlete.name }}
  • {% endfor %} {% else %}
  • Sorry, no athletes in this list.
  • {% endif %}

###if

{% if %}会对一个变量求值,如果它的值是“True”(存在、不为空、且不是boolean类型的false值),这个内容块会输出:

{% if athlete_list %}
    Number of athletes: {{ athlete_list|length }}
{% elif athlete_in_locker_room_list %}
    Athletes should be out of the locker room soon!
{% else %}
    No athletes.
{% endif %}

上述例子中,如果athlete_list不为空,就会通过使用{{ athlete_list|length }}过滤器展示出athletes的数量。

正如你所见,if标签之后可以带有一个或者多个{% elif %} 从句,也可以带有一个{% else %}从句以便在之前的所有条件不成立的情况下完成执行。这些从句都是可选的。
布尔运算符

if标签可以使用and,or或not来测试多个变量或取消给定变量:

{% if athlete_list and coach_list %}
    Both athletes and coaches are available.
{% endif %}

{% if not athlete_list %}
    There are no athletes.
{% endif %}

{% if athlete_list or coach_list %}
    There are some athletes or some coaches.
{% endif %}

{% if not athlete_list or coach_list %}
    There are no athletes or there are some coaches.
{% endif %}

{% if athlete_list and not coach_list %}
    There are some athletes and absolutely no coaches.
{% endif %}

允许同时使用and和or子句,and的优先级高于or :

{% if athlete_list and coach_list or cheerleader_list %}

将解释如下:

if (athlete_list and coach_list) or cheerleader_list

在if标记中使用实际括号是无效的语法。如果您需要它们指示优先级,则应使用嵌套的if标记。

if 标签还可能使用 ==, !=, <, >, <=, >= 和 in ,他们作用如下:
==运算符

相等。例:

{% if somevar == "x" %}
  This appears if variable somevar equals the string "x"
{% endif %}

###!=运算符

不相等。例:

{% if somevar != "x" %}
  This appears if variable somevar does not equal the string "x",
  or if somevar is not found in the context
{% endif %}

###<运算符

小于。例:

{% if somevar < 100 %}
  This appears if variable somevar is less than 100.
{% endif %}

###>运算符

大于。例:

{% if somevar > 0 %}
  This appears if variable somevar is greater than 0.
{% endif %}

###<=运算符

小于或等于。例:

{% if somevar <= 100 %}
  This appears if variable somevar is less than 100 or equal to 100.
{% endif %}

###>=运算符

大于或等于。例:

{% if somevar >= 1 %}
  This appears if variable somevar is greater than 1 or equal to 1.
{% endif %}

###in运算符

包含在内。许多Python容器支持此运算符,以测试给定值是否在容器中。以下是在 t> y中如何解释x 的一些示例:

{% if "bc" in "abcdef" %}
  This appears since "bc" is a substring of "abcdef"
{% endif %}

{% if "hello" in greetings %}
  If greetings is a list or set, one element of which is the string
  "hello", this will appear.
{% endif %}

{% if user in users %}
  If users is a QuerySet, this will appear if user is an
  instance that belongs to the QuerySet.
{% endif %}

###not in 运算符

不包含在内。这是in运算符的否定操作。

比较运算符不能像Python或数学符号中那样“链接”。例如,不能使用:

{% if a > b > c %}  (WRONG)

你应该使用:

{% if a > b and b > c %}

过滤器

你也可以在 if表达式中使用过滤器。举个例子:

{% if messages|length >= 100 %}
   You have lots of messages today!
{% endif %}

复合表达式

所有上述操作符可以组合以形成复杂表达式。对于这样的表达式,重要的是要知道在表达式求值时如何对运算符进行分组 - 即优先级规则。操作符的优先级从低至高如下:

    or
    and
    not
    in中
    ==, !=, <, >, <=, >=

(这完全依据Python)。所以,例如,下面的复杂if标签:

{% if a == b or c == d and e %}

…将被解释为:

(a == b) or ((c == d) and e)

如果你想要不同的优先级,那么你需要使用嵌套的if 标签。有时,为了清楚起见,更好的是为了那些不知道优先规则的人。
###ifchanged

检查一个值是否在上一次的迭代中改变。

{% ifchanged %} 块标签用在循环里。它可能有两个用处:
检查它已经渲染过的内容中的先前状态。并且只会显示发生改变的内容。例如, 以下的代码是输出days的列表项,不过它只会输出被修改过月份的项:

    

Archive for {{ year }}

{% for date in days %} {% ifchanged %}

{{ date|date:"F" }}

{% endifchanged %} {{ date|date:"j" }} {% endfor %}

如果标签内被给予多个值时,则会比较每一个值是否与上一次不同。例如,以下显示每次更改时的日期,如果小时或日期已更改,则显示小时:

    {% for date in days %}
        {% ifchanged date.date %} {{ date.date }} {% endifchanged %}
        {% ifchanged date.hour date.date %}
            {{ date.hour }}
        {% endifchanged %}
    {% endfor %}

ifchanged标记也可以采用可选的{% else %} 将显示如果值没有改变:

{% for match in matches %}
    
{{ match }}
{% endfor %} ifequal

如果给定的两个参数是相等的,则显示被标签包含的内容.

举个例子:

{% ifequal user.pk comment.user_id %}
    ...
{% endifequal %}

在 if 标签里面, 也可以包含 {% else %} 标签选项.

参数可以是一个硬编码的字符串,所以也可以这样:

{% ifequal user.username "adrian" %}
    ...
{% endifequal %}

ifequal标记的替代方法是使用if标记和==运算符。
###ifnotequal

就像ifequal,不过它测试两个参数不相等。

ifnotequal标记的替代方法是使用if标记和!=运算符。
include

加载模板并以标签内的参数渲染。这是一种可以引入别的模板的方法。

模板名可以是变量或者是硬编码的字符串,可以用单引号也可以是双引号.

下面这个示例包括模板“foo/bar.html”的内容:

{% include “foo/bar.html” %}

此示例包括其名称包含在变量template_name中的模板的内容:

{% include template_name %}

Changed in Django 1.7:

变量也可以是任何实现了render() 方法接口的对象,这个对象要可以接收上下文(context)。这就允许你在context中引用一个已经被编译过的Template。

被包含的模板在包含它的模板的上下文中渲染。下面这个示例生成输出“Hello, John!”:

上下文:变量person设置为“John”,变量greeting设置为“Hello”。

模板:

{% include "name_snippet.html" %}

name_snippet.html模板:

{{ greeting }}, {{ person|default:"friend" }}!

你可以使用关键字参数将额外的上下文传递到模板:

{% include “name_snippet.html” with person=“Jane” greeting=“Hello” %}

如果要仅使用提供的变量(或根本不使用变量)来渲染上下文,请使用only选项。所包含的模板没有其他变量可用:

{% include “name_snippet.html” with greeting=“Hi” only %}

注意

include 标签应该被理解为是一种"将子模版渲染并嵌入HTML中"的变种方法,而不是认为是"解析子模版并在被父模版包含的情况下展现其被父模版定义的内容".这意味着在不同的被包含的子模版之间并不共享父模版的状态,每一个子包含都是完全独立的渲染过程.

Block模块在被包含 之前 就已经被执行. 这意味着模版在被包含之前就已经从另一个block扩展并 已经被执行并完成渲染 - 没有block模块会被include引入并执行,即使父模版中的扩展模版.
load

加载自定义模板标签集。

举个例子, 下面这模板将会从package包中载入所有somelibrary 和otherlibrary 中已经注册的标签和过滤器:

{% load somelibrary package.otherlibrary %}

你还可以使用from参数从库中选择性加载单个过滤器或标记。在下面这个示例中,名为foo和bar的模板标签/过滤器将从somelibrary加载:

{% load foo bar from somelibrary %}

有关详细信息,请参阅自定义标记和过滤器库。
lorem
New in Django 1.8:

该标签之前位于django.contrib.webdesign中。

展示随机的“lorem ipsum”拉丁文本. 这个标签是用来在模版中提供文字样本以供测试用的.

用法:

{% lorem [count] [method] [random] %}

可以使用零个,一个,两个或三个参数使用{% lorem %} 。这些参数是:
Argument Description
count A number (or variable) containing the number of paragraphs or words to generate (default is 1).
method Either w for words, p for HTML paragraphs or b for plain-text paragraph blocks (default is b).
random The word random, which if given, does not use the common paragraph (“Lorem ipsum dolor sit amet…”) when generating text.

例子:

{% lorem %}将输出常见的“lorem ipsum”段落。
{% lorem 3 p %} 输出常见的“lorem ipsum”段落和两个随机段落,每个段落包含在HTML 

标签中。 {% lorem 2 w 随机 %} / t6>将输出两个随机拉丁字。

now

显示最近的日期或事件,可以通过给定的字符串格式显示。此类字符串可以包含格式说明符字符,如date过滤器部分中所述。

例:

It is {% now “jS F Y H:i” %}

注意!,如果你想要使用“raw”值,你能够反斜杠转义一个格式化字符串。在这个例子中,“o”和“f”都是反斜杠转义,因为如果不这样,会分别显示年和时间:

It is the {% now “jS \o\f F” %}

这将显示为“这是9月4日”。

注意

传递的格式也可以是预定义的DATE_FORMAT,DATETIME_FORMAT,SHORT_DATE_FORMAT或SHORT_DATETIME_FORMAT之一。预定义的格式可能会因当前语言环境和格式本地化的启用而有所不同,例如:

It is {% now “SHORT_DATETIME_FORMAT” %}

You can also use the syntax {% now “Y” as current_year %} to store the output inside a variable.This is useful if you want to use {% now %} inside a template tag like blocktrans for example:

{% now “Y” as current_year %}
{% blocktrans %}Copyright {{ current_year }}{% endblocktrans %}

New in Django 1.8.

添加了使用“as”语法的能力。
regroup

用相似对象间共有的属性重组列表.

用一个例子来解释这种复杂的标签是最好的方法:假如“places”是一个包含了"name", "population"和"country"键的字典:

cities = [
{‘name’: ‘Mumbai’, ‘population’: ‘19,000,000’, ‘country’: ‘India’},
{‘name’: ‘Calcutta’, ‘population’: ‘15,000,000’, ‘country’: ‘India’},
{‘name’: ‘New York’, ‘population’: ‘20,000,000’, ‘country’: ‘USA’},
{‘name’: ‘Chicago’, ‘population’: ‘7,000,000’, ‘country’: ‘USA’},
{‘name’: ‘Tokyo’, ‘population’: ‘33,000,000’, ‘country’: ‘Japan’},
]

你会希望用下面这种方式来展示国家和城市的信息

India
    孟买:19,000,000
    加尔各答:15,000,000
USA
    纽约:20,000,000
    芝加哥:7,000,000
Japan
    东京:33,000,000

你可以使用{% regroup %}标签来给每个国家的城市分组。以下模板代码片段将实现这一点:

{% regroup cities by country as country_list %}

    {% for country in country_list %}
  • {{ country.grouper }}
      {% for item in country.list %}
    • {{ item.name }}: {{ item.population }}
    • {% endfor %}
  • {% endfor %}

让我们来看看这个例子。{% regroup %}有三个参数: 你想要重组的列表, 被分组的属性, 还有结果列表的名字. 在这里,我们通过country属性重新分组cities列表,并调用结果country_list。

{% regroup %}产生一个清单(在本例中为country_list的组对象。每个组对象有两个属性:

grouper - 按分组的项目(例如,字符串“India”或“Japan”)。
list - 此群组中所有项目的列表(例如,所有城市的列表,其中country ='India')。

请注意,{% regroup %}不会对其输入进行排序!我们的例子依赖于事实:cities列表首先由country排序。如果cities列表不通过country对其成员进行排序,则重新分组将天真显示单个国家/地区的多个组。例如,假设cities列表已设置为此(请注意,国家/地区未分组在一起):

cities = [
{‘name’: ‘Mumbai’, ‘population’: ‘19,000,000’, ‘country’: ‘India’},
{‘name’: ‘New York’, ‘population’: ‘20,000,000’, ‘country’: ‘USA’},
{‘name’: ‘Calcutta’, ‘population’: ‘15,000,000’, ‘country’: ‘India’},
{‘name’: ‘Chicago’, ‘population’: ‘7,000,000’, ‘country’: ‘USA’},
{‘name’: ‘Tokyo’, ‘population’: ‘33,000,000’, ‘country’: ‘Japan’},
]

对于cities的输入,示例{% regroup %}以上将导致以下输出:

India
    孟买:19,000,000
USA
    纽约:20,000,000
India
    加尔各答:15,000,000
USA
    芝加哥:7,000,000
Japan
    东京:33,000,000

这个问题的最简单的解决方案是确保在你的视图代码中,数据是根据你想要显示的顺序排序。

另一个解决方案是使用dictsort过滤器对模板中的数据进行排序,如果您的数据在字典列表中:

{% regroup cities|dictsort:“country” by country as country_list %}

Grouping on other properties

一个有效的模版查找是一个regroup标签的合法的分组属性。包括方法,属性,字典健和列表项。例如,如果“country”字段是具有属性“description”的类的外键,则可以使用:

{% regroup cities by country.description as country_list %}

或者,如果country是具有choices的字段,则它将具有作为属性的get_FOO_display()方法,显示字符串而不是choices键:

{% regroup cities by get_country_display as country_list %}

{{ country.grouper }}现在会显示choices
spaceless

删除HTML标签之间的空白格.包括制表符和换行.

用法示例:

{% spaceless %}


Foo


{% endspaceless %}

这个示例将返回下面的HTML:

Foo

仅删除 tags 之间的空格 – 而不是标签和文本之间的。在此示例中,Hello周围的空格不会被删除:

{% spaceless %}

Hello

{% endspaceless %}

ssi

从1.8以后不建议使用这标签建议不再使用,将会在Django 2.0以后会被删除。用 include标签代替。

将给定文件的内容输出到页面。

像一个简单的include标签,{% ssi %}在当前页面中的另一个文件 - 必须使用绝对路径指定:

{% ssi ‘/home/html/ljworld.com/includes/right_generic.html’ %}

ssi的第一个参数可以是引用的文字或任何其他上下文变量。

如果给出了可选的parsed参数,则在当前上下文中,将包含文件的内容作为模板代码进行评估:

{% ssi ‘/home/html/ljworld.com/includes/right_generic.html’ parsed %}

Note that if you use {% ssi %}, you’ll need to define ‘allowed_include_roots’ in the OPTIONS of your template engine, as a security measure.

注意

使用ssi标记和parsed参数,文件之间没有共享状态 - 每个包含是一个完全独立的呈现过程。这意味着例如不可能使用包含的文件来定义块或改变当前页面中的上下文。

另请参阅:{% include %}。
templatetag

输出用于构成模板标记的语法字符之一。

由于模板系统没有“转义”的概念,为了显示模板标签中使用的一个位,必须使用{% templatetag %}标记。

参数指定要输出哪个模板位:
Argument Outputs
openblock {%
closeblock %}
openvariable {{
closevariable }}
openbrace {
closebrace }
opencomment {#
closecomment #}

样品用量:

{% templatetag openblock %} url ‘entry_list’ {% templatetag closeblock %}

url

返回一个绝对路径的引用(不包含域名的URL),该引用匹配一个给定的视图函数和一些可选的参数。在解析后返回的结果路径字符串中,每个特殊字符将使用iri_to_uri()编码。

这是一种不违反DRY原则的输出链接的方式,它可以避免在模板中硬编码链接路径。

{% url ‘some-url-name’ v1 v2 %}

第一个参数是视图函数中包名.模块名.函数名这样的路径package.package.module.function. 它可以是一个被引号引起来的字符串或者其他的上下文变量. 其他参数是可选的并且应该以空格隔开,这些值会在URL中以参数的形式传递. 上面的例子展示了如何传递位置参数.当然你也可以使用关键字参数.

{% url ‘some-url-name’ arg1=v1 arg2=v2 %}

不要把位置参数和关键字参数混在一起使用。URLconf所需的所有参数都应该存在。

例如,假设您有一个视图app_views.client,其URLconf接受客户端ID(此处client()是视图文件app_views .py)。URLconf行可能如下所示:

(’^client/([0-9]+)/$’, ‘app_views.client’, name=‘app-views-client’)

如果你的应用中的URLconf 已经被包含到项目 URLconf 中,比如下面这样

(’^clients/’, include(‘project_name.app_name.urls’))

…那么, 在模板文件中, 你可以很方便的创建一个接指该视图的超链接,示例如下

{% url ‘app-views-client’ client.id %}

模板标签会输出如下的字符串 /clients/client/123/.

如果您使用命名的网址格式,则可以参考网址标记中的模式名称,而不是使用视图的路径。

请注意,如果您要撤消的网址不存在,您会收到NoReverseMatch异常,这会导致您的网站显示错误网页。

如果您希望在不显示网址的情况下检索网址,则可以使用略有不同的调用:

{% url ‘some-url-name’ arg arg2 as the_url %}

I’m linking to {{ the_url }}

The scope of the variable created by the as var syntax is the {% block %} in which the {% url %} tag appears.

此{% url …为var%}语法将不导致错误,如果视图丢失。实际上,您将使用此链接来链接到可选的视图:

{% url ‘some-url-name’ as the_url %}
{% if the_url %}
Link to optional stuff
{% endif %}

如果您要检索名称空间网址,请指定完全限定名称:

{% url ‘myapp:view-name’ %}

这将遵循正常的命名空间URL解析策略,包括使用上下文对当前应用程序提供的任何提示。

自1.8版起已弃用:点状Python路径语法已弃用,将在Django 2.0中删除:

{% url ‘path.to.some_view’ v1 v2 %}

警告

不要忘记在函数路径或模式名称周围加引号,否则值将被解释为上下文变量!
verbatim

停止模版引擎在该标签中的渲染/

常见的用法是允许与Django语法冲突的JavaScript模板图层。例如:

{% verbatim %}
{{if dying}}Still alive.{{/if}}
{% endverbatim %}

You can also designate a specific closing tag, allowing the use of {% endverbatim %} as part of the unrendered contents:

{% verbatim myblock %}
Avoid template rendering via the {% verbatim %}{% endverbatim %} block.
{% endverbatim myblock %}

widthratio

为了创建条形图等,此标签计算给定值与最大值的比率,然后将该比率应用于常量。

例如:

如果this_value是175,max_value是200,并且max_width是100,则上述示例中的图像将是88像素宽(因为175 / 200 = .875; .875 * 100 = 87.5,上舍入为88)。

在某些情况下,您可能想要捕获变量中的widthratio的结果。它可以是有用的,例如,在blocktrans像这样:

{% widthratio this_value max_value max_width as width %}
{% blocktrans %}The width is: {{ width }}{% endblocktrans %}

Changed in Django 1.7:

添加了使用“as”与此标记一样的能力,如上例所示。
with

使用一个简单地名字缓存一个复杂的变量,当你需要使用一个“昂贵的”方法(比如访问数据库)很多次的时候是非常有用的

例如:

{% with total=business.employees.count %}
{{ total }} employee{{ total|pluralize }}
{% endwith %}

{% 与 %}之间可用填充变量(上例中total t5>和{% endwith %}

你可以分配多个上下文变量:

{% with alpha=1 beta=2 %}

{% endwith %}

注意

The previous more verbose format is still supported: {% with business.employees.count as total %}
内置过滤器参考
add

把add后的参数加给value

例如:

{{ value|add:“2” }}

如果 value 为 4,则会输出 6.

过滤器首先会强制把两个值转换成Int类型。如果强制转换失败, 它会试图使用各种方式吧两个值相加。它会使用一些数据类型 (字符串, 列表, 等等.) 其他类型则会失败. Day of the month, 2 digits with leading zeros.

例如,我们使用下面的值

{{ first|add:second }}

first 是 [1, 2, 3] ,second 是 [4, 5, 6], 将会输出 [1, 2, 3, 4, 5, 6].

警告

如果字符串可以被强制转换成int类型则会 summed,无法被转换,则和上面的第一个例子一样
addslashes

在引号前面加上斜杆。例如,用于在CSV中转义字符串。

例如:

{{ value|addslashes }}

如果value 是 “I’m using Django”, 输出将变成 “I’m using Django”.
capfirst

大写变量的第一个字母。如果第一个字符不是字母,该过滤器将不会生效。

例如:

{{ value|capfirst }}

如果 value 是 “django”, 输出将变成 “Django”.
center

使"value"在给定的宽度范围内居中.

例如:

“{{ value|center:“15” }}”

如果value是"Django",输出将是“ Django t7>。
cut

移除value中所有的与给出的变量相同的字符串

例如:

{{ value|cut:" " }}

如果value为“String with spaces”,输出将为"Stringwithspaces"。
date

根据给定格式对一个date变量格式化

格式类似于 PHP 的 date() 函数 (http://php.net/date) ,在一些细节上有不同.

注意

这些格式字符不在模板外的Django中使用。它们被设计为与PHP兼容,以便为设计者轻松过渡。

可用的格式字符串:
Format character Description Example output
a ‘a.m.’ or ‘p.m.’ (Note that this is slightly different than PHP’s output, because this includes periods to match Associated Press style.) ‘a.m.’
A ‘AM’ or ‘PM’. ‘AM’
b Month, textual, 3 letters, lowercase. ‘jan’
B Not implemented.
c ISO 8601 format. (Note: unlike others formatters, such as “Z”, “O” or “r”, the “c” formatter will not add timezone offset if value is a naive datetime (see datetime.tzinfo). 2008-01-02T10:30:00.000123+02:00, or 2008-01-02T10:30:00.000123 if the datetime is naive
d Day of the month, 2 digits with leading zeros. ‘01’ to ‘31’
D Day of the week, textual, 3 letters. ‘Fri’
e Timezone name. Could be in any format, or might return an empty string, depending on the datetime. ‘’, ‘GMT’, ‘-500’, ‘US/Eastern’, etc.
E Month, locale specific alternative representation usually used for long date representation. ‘listopada’ (for Polish locale, as opposed to ‘Listopad’)
f Time, in 12-hour hours and minutes, with minutes left off if they’re zero. Proprietary extension. ‘1’, ‘1:30’
F Month, textual, long. ‘January’
g Hour, 12-hour format without leading zeros. ‘1’ to ‘12’
G Hour, 24-hour format without leading zeros. ‘0’ to ‘23’
h Hour, 12-hour format. ‘01’ to ‘12’
H Hour, 24-hour format. ‘00’ to ‘23’
i Minutes. ‘00’ to ‘59’
I Daylight Savings Time, whether it’s in effect or not. ‘1’ or ‘0’
j Day of the month without leading zeros. ‘1’ to ‘31’
l Day of the week, textual, long. ‘Friday’
L Boolean for whether it’s a leap year. True or False
m Month, 2 digits with leading zeros. ‘01’ to ‘12’
M Month, textual, 3 letters. ‘Jan’
n Month without leading zeros. ‘1’ to ‘12’
N Month abbreviation in Associated Press style. Proprietary extension. ‘Jan.’, ‘Feb.’, ‘March’, ‘May’
o ISO-8601 week-numbering year, corresponding to the ISO-8601 week number (W) ‘1999’
O Difference to Greenwich time in hours. ‘+0200’
P Time, in 12-hour hours, minutes and ‘a.m.’/’p.m.’, with minutes left off if they’re zero and the special-case strings ‘midnight’ and ‘noon’ if appropriate. Proprietary extension. ‘1 a.m.’, ‘1:30 p.m.’, ‘midnight’, ‘noon’, ‘12:30 p.m.’
r RFC 2822 formatted date. ‘Thu, 21 Dec 2000 16:01:07 +0200’
s Seconds, 2 digits with leading zeros. ‘00’ to ‘59’
S English ordinal suffix for day of the month, 2 characters. ‘st’, ‘nd’, ‘rd’ or ‘th’
t Number of days in the given month. 28 to 31
T Time zone of this machine. ‘EST’, ‘MDT’
u Microseconds. 000000 to 999999
U Seconds since the Unix Epoch (January 1 1970 00:00:00 UTC).
w Day of the week, digits without leading zeros. ‘0’ (Sunday) to ‘6’ (Saturday)
W ISO-8601 week number of year, with weeks starting on Monday. 1, 53
y Year, 2 digits. ‘99’
Y Year, 4 digits. ‘1999’
z Day of the year. 0 to 365
Z Time zone offset in seconds. The offset for timezones west of UTC is always negative, and for those east of UTC is always positive. -43200 to 43200

例如:

{{ value|date:“D d M Y” }}

如果value是datetime对象(例如,datetime.datetime.now()的结果),输出将是字符串 ‘Wed 09 Jan 2008’。

传递的格式可以是预定义的格式DATE_FORMAT,DATETIME_FORMAT,SHORT_DATE_FORMAT或SHORT_DATETIME_FORMAT使用上表中显示的格式说明符。请注意,预定义的格式可能会根据当前语言环境而有所不同。

假设USE_L10N为True和LANGUAGE_CODE为例如"es"

{{ value|date:“SHORT_DATE_FORMAT” }}

the output would be the string “09/01/2008” (the “SHORT_DATE_FORMAT” format specifier for the es locale as shipped with Django is “d/m/Y”).

不使用格式字符串时使用:

{{ value|date }}

…将使用DATE_FORMAT设置中定义的格式化字符串,而不应用任何本地化。

您可以将date与time过滤器结合使用,以呈现datetime值的完整表示形式。例如。:

{{ value|date:“D d M Y” }} {{ value|time:“H:i” }}

default

如果value的计算结果为False,则使用给定的默认值。否则,使用该value。

例如:

{{ value|default:“nothing” }}

如果value为""(空字符串),则输出将为nothing。
default_if_none

如果(且仅当)value为None,则使用给定的默认值。否则,使用该value。

注意,如果给出一个空字符串,默认值将不被使用。如果要回退空字符串,请使用default过滤器。

例如:

{{ value|default_if_none:“nothing” }}

如果value为None,则输出将为字符串“nothing”。
dictsort

接受一个字典列表,并返回按参数中给出的键排序后的列表。

例如:

{{ value|dictsort:“name” }}

如果value为:

[
{‘name’: ‘zed’, ‘age’: 19},
{‘name’: ‘amy’, ‘age’: 22},
{‘name’: ‘joe’, ‘age’: 31},
]

那么输出将是:

[
{‘name’: ‘amy’, ‘age’: 22},
{‘name’: ‘joe’, ‘age’: 31},
{‘name’: ‘zed’, ‘age’: 19},
]

你也可以做更复杂的事情,如:

{% for book in books|dictsort:“author.age” %}
* {{ book.title }} ({{ book.author.name }})
{% endfor %}

如果books是:

[
{‘title’: ‘1984’, ‘author’: {‘name’: ‘George’, ‘age’: 45}},
{‘title’: ‘Timequake’, ‘author’: {‘name’: ‘Kurt’, ‘age’: 75}},
{‘title’: ‘Alice’, ‘author’: {‘name’: ‘Lewis’, ‘age’: 33}},
]

那么输出将是:

  • Alice (Lewis)
  • 1984 (George)
  • Timequake (Kurt)

dictsortreversed

获取字典列表,并返回按照参数中给出的键按相反顺序排序的列表。这与上面的过滤器完全相同,但返回的值将是相反的顺序。
divisibleby

如果value可以被给出的参数整除,则返回 True

例如:

{{ value|divisibleby:“3” }}

如果value是21,则输出将为True。
escape

转义字符串的HTML。具体来说,它使这些替换:

<转换为<
>转换为>
'(单引号)转换为'
"(双引号)转换为"
&转换为&

转义仅在字符串输出时应用,因此在连接的过滤器序列中escape的位置无关紧要:它将始终应用,就像它是最后一个过滤器。如果要立即应用转义,请使用force_escape过滤器。

将转义应用于通常会对结果应用自动转义的变量只会导致一轮转义完成。因此,即使在自动逃逸环境中使用此功能也是安全的。如果要应用多个转义通过,请使用force_escape过滤器。

例如,您可以在autoescape关闭时将escape应用于字段:

{% autoescape off %}
{{ title|escape }}
{% endautoescape %}

escapejs

转义用于JavaScript字符串的字符。这使不使字符串安全用于HTML,但确保在使用模板生成JavaScript / JSON时避免语法错误。

例如:

{{ value|escapejs }}

如果value为“testing \ r \ njavascript 'string” &lt; b&gt; escaping&lt; / b& ,输出将为“testing \ u000D \ u000Ajavascript \ u0027string \ u0022 \ u003Cb \ u003Eescaping \ u003C / b \ u003E“。
filesizeformat

格式化数值为“人类可读”的文件大小(例如’13 KB’, ‘4.1 MB’, '102 bytes’等)。

例如:

{{ value|filesizeformat }}

如果value 为123456789,输出将是117.7 MB。

文件大小和国际系统单位

严格地讲,filesizeformat 没有遵守国际单位系统建议的KiB、MiB、GiB等,它们使用1024 为幂(虽然这里使用的也是)。相反,Django 使用传统的更常用的单位名称(KB、MB、GB等)。
first

返回列表中的第一项。

例如:

{{ value|first }}

如果值是列表[‘a’, ‘b’, ‘c’] ,输出将为’a’。
floatformat

当不使用参数时,将浮点数舍入到小数点后一位,但前提是要显示小数部分。例如:
value Template Output
34.23234 {{ value|floatformat }} 34.2
34.00000 {{ value|floatformat }} 34
34.26000 {{ value|floatformat }} 34.3

如果与数字整数参数一起使用,floatformat将数字四舍五入为小数位数。例如:
value Template Output
34.23234 {{ value|floatformat:3 }} 34.232
34.00000 {{ value|floatformat:3 }} 34.000
34.26000 {{ value|floatformat:3 }} 34.260

特别有用的是传递0(零)作为参数,它将使float浮动到最接近的整数。
value Template Output
34.23234 {{ value|floatformat:“0” }} 34
34.00000 {{ value|floatformat:“0” }} 34
39.56000 {{ value|floatformat:“0” }} 40

如果传递给floatformat的参数为负,则它会将一个数字四舍五入到小数点后的位置,但前提是要显示一个小数部分。例如:
value Template Output
34.23234 {{ value|floatformat:"-3" }} 34.232
34.00000 {{ value|floatformat:"-3" }} 34
34.26000 {{ value|floatformat:"-3" }} 34.260

使用没有参数的floatformat等效于使用具有-1的参数的floatformat。
force_escape

将HTML转义应用于字符串(有关详细信息,请参阅escape过滤器)。此过滤器立即应用于,并返回一个新的转义字符串。这在需要多次转义或想要对转义结果应用其他过滤器的罕见情况下非常有用。通常,您要使用escape过滤器。

例如,如果您要捕获由linebreaks过滤器创建的

HTML元素:

{% autoescape off %}
{{ body|linebreaks|force_escape }}
{% endautoescape %}

get_digit

给定一个整数,返回所请求的数字,其中1是最右边的数字,2是第二个最右边的数字等。返回无效输入的原始值(如果输入或参数不是整数,或参数小于1)。否则,输出总是一个整数。

例如:

{{ value|get_digit:“2” }}

如果value为123456789,则输出将为8。
iriencode

将IRI(国际化资源标识符)转换为适合包含在URL中的字符串。如果您尝试在网址中使用包含非ASCII字符的字符串,这是必要的。

在已经通过urlencode过滤器的字符串上使用此过滤器是安全的。

例如:

{{ value|iriencode }}

如果value为"?test=1&me=2",输出将为"?test=1&me=2"
join

使用字符串连接列表,例如Python的str.join(list)

例如:

{{ value|join:" // " }}

如果value是列表[‘a’, ‘b’, ‘c’] / t2>,输出将是字符串“a // b // c“。
last

返回列表中的最后一个项目。

例如:

{{ value|last }}

If value is the list [‘a’, ‘b’, ‘c’, ‘d’], the output will be the string “d”.
length

返回值的长度。这适用于字符串和列表。

例如:

{{ value|length }}

如果value是[‘a’, ‘b’, ‘c’, ‘d’]或"abcd",输出将为4。
Changed in Django 1.8:

对于未定义的变量,过滤器返回0。以前,它返回一个空字符串。
length_is

如果值的长度是参数,则返回True,否则返回False。

例如:

{{ value|length_is:“4” }}

如果value是[‘a’, ‘b’, ‘c’, ‘d’]或"abcd",输出将为True。
linebreaks

用适当的HTML替换纯文本中的换行符;单个换行符变为HTML换行符(&lt; br /&gt;),新行后跟空行将成为段落(

)。

例如:

{{ value|linebreaks }}

如果value为Joel为 a slug,输出将为&lt; p&gt; Joel&lt; br /&gt;是 a slug&lt; / p&gt;
linebreaksbr

将纯文字中的所有换行符转换为HTML换行符(&lt; br /&gt;)。

例如:

{{ value|linebreaksbr }}

如果value为Joel为 a slug,输出将为Joel&lt; br /&gt;是 a slug
linenumbers

显示带行号的文本。

例如:

{{ value|linenumbers }}

如果value为:

one
two
three

输出将是:

  1. one
  2. two
  3. three

ljust

将给定宽度的字段中的值左对齐。

参数:字段大小

例如:

“{{ value|ljust:“10” }}”

如果value为Django,则输出将为“Django ”。
lower

将字符串转换为全部小写。

例如:

{{ value|lower }}

如果value为仍然 MAD 在 Yoko 输出将在仍然 mad 在 yoko。
make_list

返回转换为列表的值。对于字符串,它是一个字符列表。对于整数,在创建列表之前将参数强制转换为unicode字符串。

例如:

{{ value|make_list }}

如果value是字符串"Joel",输出将是列表[‘J’, ‘o’ , ‘e’, ‘l’]。如果value是123,则输出将是列表[‘1’, ‘2’, t15 > ‘3’]。
phone2numeric

将电话号码(可能包含字母)转换为其等效数字。

输入不必是有效的电话号码。这将很乐意转换任何字符串。

例如:

{{ value|phone2numeric }}

如果value为800-COLLECT,输出将为800-2655328。
pluralize

如果值不是1则返回一个复数形式通常用 's’表示.

例:

You have {{ num_messages }} message{{ num_messages|pluralize }}.

如果num_messages 的值是 1, 那么将会输出You have 1 message. 如果num_messages 的值是 2 那么将会输出You have 2 messages.

另外如果你需要的不是 's’后缀的话, 你可以提供一个备选的参数给过滤器

例:

You have {{ num_walruses }} walrus{{ num_walruses|pluralize:“es” }}.

对于非一般形式的复数,你可以同时指定 单复数形式,用逗号隔开.

例:

You have {{ num_cherries }} cherr{{ num_cherries|pluralize:“y,ies” }}.

注意

使用blocktrans来翻译复数形式的字符串
pprint

包装器pprint.pprint() - 用于调试,真的。
random

返回给定列表中的随机项。

例如:

{{ value|random }}

If value is the list [‘a’, ‘b’, ‘c’, ‘d’], the output could be “b”.
removetags

自1.8版起已弃用:removetags无法保证HTML安全输出,因安全问题而被弃用。请考虑使用漂白。

从输出中删除[X] HTML标签的空格分隔列表。

例如:

{{ value|removetags:“b span” }}

If value is “Joel is a slug” the unescaped output will be “Joel is a slug”.

请注意,此过滤器区分大小写。

If value is “Joel is a slug” the unescaped output will be “Joel is a slug”.

无安全保证

请注意,removetags不会保证其输出是HTML安全的。特别地,它不递归地工作,因此像"

你可能感兴趣的:(python,Django)