django模板中最常用的两种特殊符号是 {{ }} 用来表示变量和 {% %} 用来表示逻辑相关的操作
变量
{{ 变量名 }} ,由字母数字下划线组成而.
在模板语言中有特殊含义,用来获取对象相应的属性值
【举例】
在view中进行定义
def jjzz(request): l = [1,2,3] d = {"name":"jjzz"} class Hero(object): def __init__(self,name,age): self.name = name self.age = age def attack(self): return f"{self.name} is attacking ..." gailun = Hero(name='gailun',age=23) zhaoxin = Hero(name='zhaoxin',age=24) nvjing = Hero(name="kaiselin",age=22) hero_list = [gailun,zhaoxin,nvjing] return render(request,"jjzz.html",{"l":l,"d":d,"hero_list":hero_list})中HTML支持的写法
HTML中的基础用法
<body> {# 获取列表l中的元素 #} <p>第一个元素:{{ l.0 }}</p> <p>第三个元素:{{ l.2 }}</p> {# 获取字典d中的key #} <p>获取d中的name:{{ d.name }}</p> {# 获取Hero对象的name属性 #} <p>{{ hero_list.0.name }}</p> {# 使用 . 只能调用不带参数的方法#} <p>{{ hero_list.1.attack }}</p> </body>
【注意】
当模板系统遇到.
时,会按照如下的顺序去查询:
-
在字典中查询
-
属性或者方法
-
数字索引
内置Filters
过滤器,用来修饰变量的显示结果
语法 {{ 变量名|过滤器名:参数 }} 注意:
两边不能有空格,过滤器与给过滤器的参数是一个整体,而且过滤器只能有一个参数
default
定义变量的默认值,在没有传递变量或者参数没有定义(不存在或者为空)时,使用默认值
{{ value|default_name:"nothing"}} # 如果value值没有没传的话就显示nothing 源码解释: @register.filter(is_safe=False) def default(value, arg): """If value is unavailable, use given default.""" return value or arg
【注意】在settings中的TEMPLATES的OPTIONS可以增加一个选项:string_if_invalid:'找不到',可以替代default的的作用,优先级高于直接设置default。
default_if_none
使用形式: {{ value | default_if_none:"nothing" }} ,
意义:如果value是None,那么输出将是nothing.
源码解释
@register.filter(is_safe=False) def default_if_none(value, arg): """If value is None, use given default.""" if value is None: return arg return value
【与default的区别】
None:不存在即为空,'',None
unavailable:None,False,[],{},''等都可以算是不可用
符号 | defaul:"noting" | default_if_none:"noting" |
---|---|---|
{} | noting | {} |
"" | noting | noting |
None | noting | noting |
[] | noting | [] |
False | noting | False |
filesizeformat
将值转换成便于用户可读的方式 。例如:1.1KB,1.1MB,1.1GB
{{ value|filesizeformat }} # 比如变量value的值为100000,显示为97.7 KB
add
给变量加参数
{{ value|add:"2" }} # value是数字4,则输出结果为6。 {{ l1|add:l2 }} # 如果l1是 [1,2,3] ,l2是 [4,5,6] ,那输出结果是 [1,2,3,4,5,6]
lower
{{ value|lower }} # 变小写,还能给布尔值变大小写呢
upper
{{ value|upper}} # 变大写
title
{{ value|title }} # 单词首字母大写
ljust
"{{ value|ljust:"10" }}" # 左对齐
rjust
"{{ value|rjust:"10" }}" # 右对齐
center
"{{ value|center:"15" }}" # 居中
length
{{ value|length }} # 返回value的长度,如 value=['a', 'b', 'c', 'd']的话,就显示4
slice
{{value|slice:"2:-1"}} # 切片
first
{{ value|first }} # 取第一个元素
last
{{ value|last }} # 去最后一个元素
join
{{ value|join:" // " }} # 使用字符串拼接列表,功能等同于python中的str.join(list)
truncatechars
如果字符串字符多于指定的字符数量,那么会被截断。截断的字符串将以可翻译的省略号序列(“...”)结尾。
参数:截断的字符数,
{{ value|truncatechars:9}} # 截断9个字符
truncatewords
将字符串转换为省略表达方式,以空格计数单词
{{ value|truncatewords:9}} # 阶段9个单词
date
{{ value|date:"Y-m-d H:i:s"}} # 日期格式化
也可以在settings中进行日期格式的定义
USE_L10N = False DATETIME_FORMAT = 'Y-m-d H:i:s' DATE_FORMAT = 'Y-m-d' TIME_FORMAT = 'H:i:s'
字典拆包
{{ dic.key }} {{ dic.keys }} {{ dic.values }} {{ dic.items}} 【注意】Django的模板语言中属性的优先级大于方法 例如dic = {"name":"jjzz", "items": "100"} 在模板中执行{{ dic.items }} 显示100
safe
通常情况下,django模板会对HTML标签和JS语法进行自动转义,就是将包含的html标签输出,而不被解释执行,原因是当显示用户提交字符串时,可能包含一些攻击性的代码,如js脚本。例如<
会转换为<
,但是有些时候我们不希望这些元素被HTML转义,那么这是就需要safe过滤器来告诉django这段代码是安全的,不需要转义。
{{ value|safe}}
【举例】
views中设置
link = '<a href="https://cn.bing.com">这是bing搜索</a>' return(request,"jjzz.html",{"link":link})
HTML模板中设置
<p>{{ link }}</p> <p>{{ link|safe }}</p>
显示
还可以在views中在向模板传递数据前使用mark_safe
来进行防转义设置
from django.utils.safestring import mark_safe a_link= mark_safe('<a href="http://www.baidu.com">跳转</a>')
自定义Filter
自定义的过滤器知识带一个或者两个参数的python函数
定义
-
在app下创建一个名为templatetags的python包,确保该app已经在settings.py中INSTALLED_APPS注册了。
-
在包内创建py文件 — > 自定义 jjzz.py
-
在py文件中写入:
from django import template register = template.Library() # register不能变
-
定义函数 + 加装饰
from django.utils.safestring import mark_safe @register.filter def new_safe(value, arg=None): # arg 最多有一个 return mark_safe(value)
在模板中使用:
{% load jjzz %} {{ '<a href="https://cn.bing.com">这是bing搜索</a>'|new_safe }}