Django模板:

  官方文档:https://docs.djangoproject.com/en/1.11/ref/templates/language/

常用语法:

1 {{ }}表示变量,在模板渲染的时候替换成值,{% %}表示逻辑相关的操作,{#....#}代表注释
2 {# 取l中的第一个参数 #}
3 {{ l.0 }}
4 {# 取字典中key的值 #}
5 {{ d.name }}
6 {# 取对象的name属性 #}
7 {{ person_list.0.name }}
8 {# .操作只能调用不带参数的方法 #}
9 {{ person_list.0.dream }}

注:当模板系统遇到一个(.)时,会按照如下的顺序去查询:

  1. 在字典中查询
  2. 属性或者方法
  3. 数字索引

Filters

用来修改变量的显示结果。

语法: {{ value|filter_name:参数 }}

‘|’左右没有空格没有空格没有空格

1 #flter支持链式操作
2 #例如:
3 {{ value|first|upper}}     #首字母大写

 

 

1、默认值

1 default
2 {{ value|default:"nothing"}}    #如果value值没传的话就显示nothing

2、格式化值

1 1 default
2 2 {{ value|default:"nothing"}}    #如果value值没传的话就显示nothing

3、相加

1 add
2 #给变量加参数
3 {{ value|add:"2" }}    #value是数字4,则输出结果为6。
4 {{ first|add:second }} #如果first是 [1,.2,3] ,second是 [4,5,6] ,那输出结果是 [1,2,3,4,5,6] 。

4、大小写

lower
#小写
{{ value|lower }}

upper
#大写
{{ value|upper}}

5、对齐方式

ljust
 #左对齐
 {{ value|ljust:"10" }}
 rjust
 
 #右对齐
 {{ value|rjust:"10" }}
 
 center
 #居中
 {{ value|center:"15" }}

5、标题

1 #标题
2 {{ value|title }}

6、返回value的长度

1 {{ value|length }}
2 #返回value的长度,如 value=['a', 'b', 'c', 'd']的话,就显示4.

7、切片

 1 slice  
 2 #切片
 3 {{value|slice:"2:-1"}}
 4 
 5 first
 6 #取第一个元素
 7 {{ value|first }}
 8 
 9 last
10 #取最后一个元素
11 {{ value|last }}

8、字符串拼接

1 #使用字符串拼接列表。同python的str.join(list)。
2 {{ value|join:" // " }}

 

9、字符截取

1 truncatechars
2 #如果字符串字符多于指定的字符数量,那么会被截断。截断的字符串将以可翻译的省略号序列(“...”)结尾。
3 #参数:截断的字符数
4 {{ value|truncatechars:9}}

 

10、日期格式化:

1 date
2 #日期格式化
3 {{ value|date:"Y-m-d H:i:s"}}

 

11、不必转义

safe
#Django的模板中会对HTML标签和JS等语法标签进行自动转义,原因显而易见,这样是为了安全。但是有的时候我们可能不希望这些HTML元素被转义,比如我们做一个内容管理系统,后台添加的文章中是经过修饰的,这些修饰可能是通过一个类似于FCKeditor编辑加注了HTML修饰符的文本,如果自动转义的话显示的就是保护HTML标签的源文件。为了在Django中关闭HTML的自动转义有两种方式,如果是一个单独的变量我们可以通过过滤器“|safe”的方式告诉Django这段代码是安全的不必转义。

比如:

value = "<a href='#'>点我</a>"

{{ value|safe}}

 

 

自定义filter

自定义过滤器只是带有一个或两个参数的Python函数:

  • 变量(输入)的值 – -不一定是一个字符串
  • 参数的值 – 这可以有一个默认值,或完全省略

例如,在过滤器{{var | foo:“bar”}}中,过滤器foo将传递变量var和参数“bar”

自定义filter代码文件摆放位置:

1 app01/
2     __init__.py
3     models.py
4     templatetags/  # 在app01下面新建一个package package
5         __init__.py
6         app01_filters.py  # 建一个存放自定义filter的py文件
7     views.py

 

编写自定义的filter

 1 from django import template
 2 register = template.Library()
 3 
 4 
 5 @register.filter
 6 def fill(value, arg):
 7     return value.replace(" ", arg)
 8 
 9 
10 @register.filter(name="addSB")
11 def add_sb(value):
12     return "{} SB".format(value)

 

 

使用自定义的filter

1 {# 先导入我们自定义filter那个文件 #}
2 {% load app01_filters %}
3 
4 {# 使用我们自定义的filter #}
5 {{ somevariable|fill:"__" }}
6 {{ d.name|addSB }}

 

版权声明:本文为pengsq原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/pengsq/p/10067610.html