一、模板的组成

HTML代码+逻辑控制代码

二、逻辑控制代码的组成

1.变量(使用双大括号来引用变量)

{{ var_name }}

2.标签(tag)的使用(使用大括号和百分号的组成来表示使用tag)

{% load staticfiles %}

3.过滤器(filter)的使用

{{ ship_date|date:"F j,Y" }},ship_date变量传给date过滤器,date过滤器通过使用"F j,Y"这几个参数来格式化日期数据。 "|"代表类似Unix命令中的管道操作。

三、常用标签(tag)

1.{% if %} 的使用

可以使用and,or,not来组织逻辑,新版本中已经支持 {% elif %}

2.{% ifequal %} 和 {% ifnotequal %} 的使用

比较是否相等,只限于简单的类型,如字符串,整数,小数的比较,列表,字典,元组不支持

3.{% for %} 的使用

循环一个列表。可以使用empty关键字来进行为空时处理;可以使用resersed关键字来倒序遍历;

for标签中,可以使用forloop

{{ forloop.counter }}: 当前循环计数,从1开始

{{ forloop.counter0 }}:当前循环计数,从0开始,标准索引方式

{{ forloop.revcounter }}:当前循环的倒数计数,从列表长度开始

{{ forloop.revcounter0 }}:当前循环的倒数计数,从列表长度减1开始,标准索引方式

{{ forloop.first }}:布尔值,判断是不是循环的第一个元素

{{ forloop.last}}:布尔值,判断是不是循环的最后一个元素

4.{% cycle %}

在循环时轮流使用给定的字符串列表中的值。

5.{# #} 单行注释,{% comment %} 多行注释

6.{% csrf_token %}

生成csrf_token的标签,用于防止跨站攻击验证

7.{% debug %}

调用调试信息

8.{% filter %}

将filter标签圈定的内容执行过滤器操作

9.{% autoescape %}

自动转义设置

10.{% firstof %}

输出第一个值不等于False的变量

11.{% load %}

加载标签库

12.{% now %}

获得当前时间

13.{% spaceless %}

移除空格

14.{% url %}

引入路由配置的name的地址

15.{% verbatim %}

禁止render

16.{% with %}

用更简单的变量名缓存复杂的变量名

...

更多详见:https://docs.djangoproject.com/en/1.10/ref/templates/builtins/

四、常用过滤器(filter)

1.add

给变量加上相应的值

2.addslashes

给变量中的引号前加上斜线

3.capfirst

首字母大写

4.cut

从字符串中移除指定的字符

5.date

格式化日期字符串

{{ value|date:"D d M Y" }}

If value is a datetime object (e.g., the result of datetime.datetime.now()), the output will be the string 'Wed 09 Jan2008'.

6.default

如果值是False,就替换成设置的默认值,否则就使用本来的值

7.default_if_none

如歌值为None,就替换成设置的默认值,否则就使用本来的值

8.dictsort

按照设定参数(key)对应的value对列表进行排序

9.dictsortreversed

和上面恰好相反

10.divisibleby

是否能够被某个数字整除,是的话返回True,否则返回False

11.escape

对字符串进行转义

12.escapejs

替换value中的某些字符,以适应JAVASCRIPT和JSON格式

13.filesizeformat

格式化文件大小显示

14.first

返回列表中的第一个值

15.last

返回列表中的最后一个值

16.floatformat

格式化浮点数

17.length

求字符串或者列表长度

18.length_js

比较字符串或者列表的长度

19.urlencode

对URL进行编码处理

20.upper\lower

大写\小写

21.safe

对某个变量关闭自动转义

22.slice

切片操作

{{ some_list|slice:":2" }}

If some_list is ['a', 'b', 'c'], the output will be ['a', 'b'].

23.time

格式化时间

{{ value|time:"H:i" }}

24.timesince

格式化时间

25.truncatechars

按照字符截取字符串

{{ value|truncatechars:9 }}

If value is "Joel is a slug", the output will be "Joel i...".

26.truncatewords

按照单词截取字符串

27.striptags

过滤掉html标签

{{ value|striptags }}

If value is "<b>Joel</b> <button>is</button> a <span>slug</span>", the output will be "Joel is a slug".

标签和过滤器,更多详见:https://docs.djangoproject.com/en/1.10/ref/templates/builtins/


***微信扫一扫,关注“python测试开发圈”,了解更多测试教程!***

Django进阶Template篇001 - 常用模板标签及过滤器的更多相关文章

  1. Django进阶Template篇002 - 模板包含和继承

    包含 {% include %} 允许在模板中包含其他模板的内容. {% include "foo/bar.html" %} {% include template_name %} ...

  2. Django框架基础知识05-自定义模板标签与过滤器

    根据一定规则,自己定义出符合需求功能的.用在任何你有需求的地方,因为内置的满足不了我们的需求,不同的东西有不同的定义规则 目前最最重要的就是HOW 一 文件路径配置: templates 存放自定义 ...

  3. Django进阶Model篇001 - mysql 数据库的配置

    django 默认支持sqlite.mysql.oracle.postgresql数据库,像db2和sqlserver之类的数据库需要第三方的支持,具体详见: https://docs.djangop ...

  4. Django-常用模板标签及过滤器

    常用模板标签及过滤器 标签和过滤器完整介绍 https://docs.djangoproject.com/en/1.11/ref/templates/builtins/ 模板的组成 HTML代码+ 逻 ...

  5. python Django教程 之模板渲染、循环、条件判断、常用的标签、过滤器

    python3.5 manage.py runserver python Django教程 之模板渲染.循环.条件判断.常用的标签.过滤器 一.Django模板渲染模板 1. 创建一个 zqxt_tm ...

  6. Django 笔记(四)模板标签 ~ 自定义过滤器

    模板标签: 标签在渲染的过程中提供任意的逻辑 语法: 由{% ... %} 和 {% end... %} 常用标签: with:类似取别名 模版继承: Django模版引擎中最强大也是最复杂的部分就是 ...

  7. Django(十五)模板详解:模板标签、过滤器、模板注释、模板继承、html转义

    一.模板的基础配置及使用 [参考]https://docs.djangoproject.com/zh-hans/3.0/topics/templates/ 作为Web框架,Django提供了模板,用于 ...

  8. Django 学习笔记(五)模板标签

    关于Django模板标签官方网址https://docs.djangoproject.com/en/1.11/ref/templates/builtins/ 1.IF标签 Hello World/vi ...

  9. Django进阶Model篇005 - QuerySet常用的API

    django.db.models.query.QuerySet QuerySet特点: 1.可迭代 2.可切片 查询相关API 1.get(**kwargs):返回与所给的筛选条件相匹配的对象,返回结 ...

随机推荐

  1. elasticsearch数据迁移——elasticsearch-dump使用

    先安装好nodejs和nodejs的包管理工具npm.然后安装elasticsearch-dump: npm install elasticdump 下面迁移数据: 先在目的地址创建一个index来储 ...

  2. Css选择器定位详解

    1.使用 class 属性来定位元素,方法如下: driver.findElement(By.cssSelector("input.login")); 即可以先指定一个 HTML的 ...

  3. 对比MySQL,你究竟在什么时候更需要MongoDB(转)

    译文:对比MySQL,你究竟在什么时候更需要MongoDB 原文链接: When Should I Use MongoDB rather than MySQL (or other RDBMS): Th ...

  4. 前端(css引入的3中方式)

    一.css引入的三种方式 行间式 在标签头部的style属性内 属性值满足的是css语法 属性值用key:value形式赋值,value具有单位 属性值之间用;隔开 外联式(企业开发中使用这种方式) ...

  5. atitit.client连接oracle数据库的方式总结

    client连接oracle数据库的方式总结 文件夹 Java程序连接一般使用jar驱动连接.. ... 桌面GUI一般採取c语言驱动oci.dll 直接连接... 间接连接(须要配置tns及其env ...

  6. node.js---sails项目开发(2)

    1.安装mongoDB,这里用brew安装 brew install mongodb 2. 启动数据库 mongod 3.再打开一个终端,连接数据库 mongo 4.启动成功后,接下来就是新建一个数据 ...

  7. Android_Kotlin 代码学习

    https://github.com/ldm520/Android_Kotlin_Demo

  8. Jquery 实现跨域处理

    JS部分代码: $.ajax({ url:url, dataType:'jsonp', data:{title:title}, jsonp:'callback', success:function(l ...

  9. PyMySQL介绍

    pymysql介绍 PyMySQL介绍 PyMySQL 是在 Python3.x 版本中用于连接 MySQL 服务器的一个库,Python2中则使用mysqldb Django中也可以使用PyMySQ ...

  10. Java技术学习路线

    转载 作者:David 链接:https://www.zhihu.com/question/25255189/answer/86898400来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商 ...