zoukankan      html  css  js  c++  java
  • Django 模板标签[转]

    Django 模板标签
    if/else 标签

    基本语法格式如下:

    {% if condition %}
         ... display
    {% endif %}

    或者:

    {% if condition1 %}
       ... display 1
    {% elif condiiton2 %}
       ... display 2
    {% else %}
       ... display 3
    {% endif %}

    根据条件判断是否输出。if/else 支持嵌套。

    {% if %} 标签接受 and , or 或者 not 关键字来对多个变量做判断 ,或者对变量取反( not ),例如:

    {% if athlete_list and coach_list %}
         athletes 和 coaches 变量都是可用的。
    {% endif %}

    for 标签

    {% for %} 允许我们在一个序列上迭代。

    与Python的 for 语句的情形类似,循环语法是 for X in Y ,Y是要迭代的序列而X是在每一个特定的循环中使用的变量名称。

    每一次循环中,模板系统会渲染在 {% for %} 和 {% endfor %} 之间的所有内容。
    例如,给定一个运动员列表 athlete_list 变量,我们可以使用下面的代码来显示这个列表:

    <ul>
    {% for athlete in athlete_list %}
        <li>{{ athlete.name }}</li>
    {% endfor %}
    </ul>

    给标签增加一个 reversed 使得该列表被反向迭代:

    {% for athlete in athlete_list reversed %}
    ...
    {% endfor %}

    可以嵌套使用 {% for %} 标签:

    {% for athlete in athlete_list %}
        <h1>{{ athlete.name }}</h1>
        <ul>
        {% for sport in athlete.sports_played %}
            <li>{{ sport }}</li>
        {% endfor %}
        </ul>
    {% endfor %}

    ifequal/ifnotequal 标签

    {% ifequal %} 标签比较两个值,当他们相等时,显示在 {% ifequal %} 和 {% endifequal %} 之中所有的值。

    下面的例子比较两个模板变量 user 和 currentuser :

    {% ifequal user currentuser %}
        <h1>Welcome!</h1>
    {% endifequal %}

    和 {% if %} 类似, {% ifequal %} 支持可选的 {% else%} 标签:8

    {% ifequal section 'sitenews' %}
        <h1>Site News</h1>
    {% else %}
        <h1>No News Here</h1>
    {% endifequal %}

    注释标签

    Django 注释使用 {# #}。

    {# 这是一个注释 #}

    过滤器

    模板过滤器可以在变量被显示前修改它,过滤器使用管道字符,如下所示:

    {{ name|lower }}

    {{ name }} 变量被过滤器 lower 处理后,文档大写转换文本为小写。

    过滤管道可以被* 套接* ,既是说,一个过滤器管道的输出又可以作为下一个管道的输入:

    {{ my_list|first|upper }}

    以上实例将第一个元素并将其转化为大写。

    有些过滤器有参数。 过滤器的参数跟随冒号之后并且总是以双引号包含。 例如:

    {{ bio|truncatewords:"30" }}

    这个将显示变量 bio 的前30个词。

    其他过滤器:

        addslashes : 添加反斜杠到任何反斜杠、单引号或者双引号前面。
        date : 按指定的格式字符串参数格式化 date 或者 datetime 对象,实例:

        {{ pub_date|date:"F j, Y" }}

        length : 返回变量的长度。

    include 标签

    {% include %} 标签允许在模板中包含其它的模板的内容。

    下面这两个例子都包含了 nav.html 模板:

    {% include "nav.html" %}

    模板继承

    模板可以用继承的方式来实现复用。

    接下来我们先创建之前项目的 templates 目录中添加 base.html 文件,代码如下:

    <html>
      <head>
        <title>Hello World!</title>
      </head>

      <body>
        <h1>Hello World!</h1>
        {% block mainbody %}
           <p>original</p>
        {% endblock %}
      </body>
    </html>

    以上代码中,名为mainbody的block标签是可以被继承者们替换掉的部分。

    所有的 {% block %} 标签告诉模板引擎,子模板可以重载这些部分。

    hello.html中继承base.html,并替换特定block,hello.html修改后的代码如下:

    {% extends "base.html" %}

    {% block mainbody %}
    <p>继承了 base.html 文件</p>
    {% endblock %}

    第一行代码说明hello.html继承了 base.html 文件。可以看到,这里相同名字的block标签用以替换base.html的相应block。

    重新访问地址http://127.0.0.1:8000/hello/,输出结果如下:

  • 相关阅读:
    面向对象介绍
    常用模块2
    常用模块1
    常用模块3
    模块导入以及常用模块
    模块介绍
    Astra: Apache Cassandra的未来是云原生
    麦格理银行借助DataStax Enterprise (DSE) 驱动数字化转型
    Apache Cassandra使用报告2020
    比较Apache Cassandra的压力测试工具
  • 原文地址:https://www.cnblogs.com/songjinduo/p/5132933.html
Copyright © 2011-2022 走看看