Django的模板语言的目的是取得力量和易用性之间的平衡,与其他的模板语言相比,django模板语言显得更简单,更专一,

django模板系统由模板,变量,过滤器,标签,注释等主要部分组成

模板

一个模板是一个简单的文本文件,它可以生成任何基于文本的格式,html,csv,xml等等

模板里面包含变量,过滤器,标签和注释,下面是一个简单的模板文件

  1. {% extends "base_generic.html" %}
  2. {% block title %}{{ section.title }}{% endblock %}
  3. {% block content %}
  4. <h1>{{ section.title }}</h1>
  5. {% for story in story_list %}
  6. <h2>
  7. <a href="{{ story.get_absolute_url }}">
  8. {{ story.headline|upper }}
  9. </a>
  10. </h2>
  11. <p>{{ story.tease|truncatewords:"100" }}</p>
  12. {% endfor %}
  13. {% endblock %}

变量

变量格式:{{ variable }}

变量解析:当模板引擎碰到一个变量的时候,会计算变量然后用结果去代替他

变量的命名:字母数字和下划线的组合,.(点号)不可用,因为点号有特殊的意义

如果变量不存在的时候,{{variable}}会被解析为''(一个空字符串)

过滤器

修改变量的展示方式

格式:{{ variable|filter }},展示变量经过filter后的结果,例如{{ name|lower }}战术name的小写形式,|是管道

filter可以串联,例如{{ text|escape|linebreaks }}

filter可以有参数,用冒号表示,例如 {{ bio|truncatewords:30 }}

filter参数如果有空格,必须用引号括起来,例如:{{ list|join:", " }}

django有很多内建的过滤器,我们下一节再讲,因为有30个之多,足以成一节了

标签

标签比变量和过滤器要复杂的多,有些是在输出上产生内容,有些是控制文本流(通过循环和逻辑),还有一些是加载外部的一些内容进入模板

格式:{% tag %}

标签基本都是成对出现的,如:{% tag %} ... tag contents ... {% endtag %}

django内建的标签有很多,接近40个,足以成一节,下下节再说的

注释

注释,不用解释了吧

格式:{# #}

但是这个注释标签只能注释单行的文本

如果你想注释多行的话,要通过comment标签

模板继承

模板系统最有力也是最复杂的部分--模板继承,你可以在父模板中使用block标签定义一些列的变量,然后再字模板中覆盖他们,看下面的例子:

base.html

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <link rel="stylesheet" href="style.css" />
  5. <title>{% block title %}My amazing site{% endblock %}</title>
  6. </head>
  7. <body>
  8. <div id="sidebar">
  9. {% block sidebar %}
  10. <ul>
  11. <li><a href="/">Home</a></li>
  12. <li><a href="/blog/">Blog</a></li>
  13. </ul>
  14. {% endblock %}
  15. </div>
  16. <div id="content">
  17. {% block content %}{% endblock %}
  18. </div>
  19. </body>
  20. </html>

一个子模板如下,关键是extends标签

  1. {% extends "base.html" %}
  2. {% block title %}My amazing blog{% endblock %}
  3. {% block content %}
  4. {% for entry in blog_entries %}
  5. <h2>{{ entry.title }}</h2>
  6. <p>{{ entry.body }}</p>
  7. {% endfor %}
  8. {% endblock %}

渲染的效果如下:子模板中有的标签会覆盖父模板的内容如title,子模板没有覆盖的标签将从父模板哪里继承过来,如sidebar

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <link rel="stylesheet" href="style.css" />
  5. <title>My amazing blog</title>
  6. </head>
  7. <body>
  8. <div id="sidebar">
  9. <ul>
  10. <li><a href="/">Home</a></li>
  11. <li><a href="/blog/">Blog</a></li>
  12. </ul>
  13. </div>
  14. <div id="content">
  15. <h2>Entry one</h2>
  16. <p>This is my first entry.</p>
  17. <h2>Entry two</h2>
  18. <p>This is my second entry.</p>
  19. </div>
  20. </body>
  21. </html>

下面是一些tips:

  • 如果你要使用extends标签,请确保extends在子模板中时第一个标签
  • 在父模板中的block标签越多越好
  • 如果你在多个子模板中出现了重复的内容,是时候考虑把它们放到父模板里面了
  • {{ block.super }} 可以访问父模板中对应block的值,当你仅仅是想在父模板的基础上添加内容而不是覆盖的时候 ,可能会用到这个值

自动HTML转义

威胁主要来自跨站点攻击(XXS)

很明显,用户提交的内容是不能被盲目的信任的,因为一些别有用心的用户可能会利用这种盲目的信任来做一些你意想不到的事情,例如在内容中内嵌了一段javascript代码等等,所以django是默认自动转义的,即是有下面的转换

  • < is converted to &lt;
  • > is converted to &gt;
  • ' (single quote) is converted to '
  • " (double quote) is converted to &quot;
  • & is converted to &amp;

如果你真的要放弃自动转义,或者你有自己的需要的,或者你确信用户的输入没有威胁的时候,你可以关闭自动HTML转义

在变量中,你可以这样做

  1. This will be escaped: {{ data }}
  2. This will not be escaped: {{ data|safe }}

在标签中,你可以这样做

  1. {% autoescape off %}
  2. This will not be auto-escaped: {{ data }}.
  3.  
  4. Nor this: {{ other_data }}
  5. {% autoescape on %}
  6. Auto-escaping applies again: {{ name }}
  7. {% endautoescape %}
  8. {% endautoescape %}

访问方法调用

在模板中,大多数的方法调用还是可用的,但,方法是不可能在模板中定义的,所有的属性方法必须在模板之前定义好

  1. {% for comment in task.comment_set.all %}
  2. {{ comment }}
  3. {% endfor %}
  4. {{ task.comment_set.all.count }}
  5. # In model
  6. class Task(models.Model):
  7. def foo(self):
  8. return "bar"
  9.  
  10. # In template
  11. {{ task.foo }}

p

10:django 模板语言的更多相关文章

  1. Django模板语言初识

    一.Django框架简介 1.MVC框架 MVC,全名是Model View Controller,是软件工程中的一种软件架构模式,把软件系统分为三个基本部分:模型(Model).视图(View)和控 ...

  2. Django模板语言的复用

    一.include标签 由于在项目中,往往会出现多个页面拥有一个或几个相同的页面版块,或是一个页面多个页面版块是相同的,基于这个问题,我们可以采用模板语言复用include标签来帮我们解决,这样就避免 ...

  3. Django模板语言相关内容 Djan

    Django模板语言相关内容   Django模板系统 官方文档 常用语法 只需要记两种特殊符号: {{  }}和 {% %} 变量相关的用{{}},逻辑相关的用{%%}. 变量 {{ 变量名 }} ...

  4. Django——模板语言相关内容

    Django模板语言相关内容   Django模板系统 官方文档 常用语法 只需要记两种特殊符号: {{  }}和 {% %} 变量相关的用{{}},逻辑相关的用{%%}. 变量 {{ 变量名 }} ...

  5. Django模板语言与视图(view)

    常用语法 {{  }}和{% %} 变量相关的用{{}} , 逻辑相关的用{% %} 变量 在Django的模板语言中按此语法使用:{{ 变量名 }}. 当模版引擎遇到一个变量,它将计算这个变量,然后 ...

  6. Django模板语言,过滤器整理

    Django模板语言,过滤器整理 1. add {{ value|add:"2" }} 把add后的参数加给value: 处理时,过滤器首先会强制把两个值转换成Int类型. 如果强 ...

  7. Django模板语言,标签整理

    Django模板语言 标签 内置标签引用 1. autoescape 控制自动转义是否可用. 这种标签带有任何 on 或 off 作为参数的话,他将决定转义块内效果. 该标签会以一个endautoes ...

  8. Django模板语言(一)

    1,Django模板语言 1.1>基础语法:1.1.1,变量相关:{{ 变量名 }},1.1.2,逻辑相关{% ... %} 在Django模板语言中按此语法使用:{{ 变量名 }},当模板引擎 ...

  9. Django模板语言 标签整理

    Django模板语言 标签 内置标签引用 1. autoescape 控制自动转义是否可用. 这种标签带有任何 on 或 off 作为参数的话,他将决定转义块内效果. 该标签会以一个endautoes ...

随机推荐

  1. POJ1269:Intersecting Lines——题解

    http://poj.org/problem?id=1269 题目大意:给四个点,求前两个点所构成的直线和后两个点所构成的直线的位置关系(平行,重合,相交),如果是相交,输出交点坐标. ——————— ...

  2. BZOJ4889 & 洛谷3759:[TJOI2017]不勤劳的图书管理员——题解

    https://www.lydsy.com/JudgeOnline/problem.php?id=4889 https://www.luogu.org/problemnew/show/P3759 加里 ...

  3. [Leetcode] pascals triangle ii 帕斯卡三角

    Given an index k, return the k th row of the Pascal's triangle. For example, given k = 3,Return[1,3, ...

  4. BZOJ4103 [Thu Summer Camp 2015]异或运算 【可持久化trie树】

    题目链接 BZOJ4103 题解 一眼看过去是二维结构,实则未然需要树套树之类的数据结构 区域异或和,就一定是可持久化\(trie\)树 观察数据,\(m\)非常大,而\(n\)和\(p\)比较小,甚 ...

  5. 洛谷 P3332 [ZJOI2013]K大数查询 解题报告

    P3332 [ZJOI2013]K大数查询 题目描述 有\(N\)个位置,\(M\)个操作.操作有两种,每次操作如果是\(\tt{1\ a\ b\ c}\)的形式表示在第\(a\)个位置到第\(b\) ...

  6. JN5169 --------- zigbee代码

    队列: 需要创建3个标准队列(只创建不使用): ------Queue with handle zps_msgMlmeDcfmInd to receive IEEE 802.15.4 MACcomma ...

  7. Azure Pipelines

    https://docs.microsoft.com/en-us/azure/devops/pipelines/?view=vsts

  8. [LeetCode] 10. Regular Expression Matching ☆☆☆☆☆

    Implement regular expression matching with support for '.' and '*'. '.' Matches any single character ...

  9. ZooKeeper观察者(十三)

    观察者:扩展ZooKeeper而不影响写性能 尽管ZK运行地很好通过客户端直接连接来投票集群的成员,这个结构使它很难扩展出很多客户端.问题是当我们加入更多的投票成员时,写性能就会下降.这是因为一个写操 ...

  10. lambda表达式的应用例子和JavaSE 8特性

    在JavaSE 8 引入了lambda表达式,lambda表达式的引入带来的好处是:通过语法上的改进,减少开发人员需要编写和维护的代码数量.这个在下面使用和不使用lambda的对比中可以清晰看出来. ...