Django之模板系统
变量的使用:
def test(request): num=1 s='hello' li=[1,2,['a','b']] dic={'name':'w','age':1} se={1,2,3} tup=(1,2,3,4) def my_test(): return '这是my_test' class test1: def __init__(self,name): self.name=name @classmethod def classM(cls): return '这是类方法' @staticmethod def staM(): return '这是staticmethod方法' def get_name(self): return self.name t=test1('wdj') return render(request,'test.html',locals())
在views中定义上面的函数,locals()是将命名空间中所有变量全部传入前端
上图传入的变量有:整型,字符串,列表,字典,集合,元组,无参函数,类的对象
在前端的使用方式:
<p>数字:{{ num }}</p> <p>字符串:{{ s }}</p> <p>列表:{{ li }}</p> <p>字典:{{ dic }}</p> <p>集合{{ se }}</p> <p>元组:{{tup }}</p> <p>函数:{{my_test}}</p> <P>对象:{{ t }}</P> <P>对象属性{{ t.name }}</P> <P>对象函数{{ t.get_name }}</P> <P>类函数{{ t.classM }}</P> <P>全局函数{{ t.staM }}</P>
模板中支持的写法:
{# 取l中的第一个参数 #}{{ l.0 }}
{# 取字典中key的值 #} {{ d.name }} {# 取对象的name属性 #} {{ person_list.0.name }} {# .操作只能调用不带参数的方法 #} {{ person_list.0.dream }}
注意:传进来的函数一定不能是含参函数
Filter(过滤器):
语法: {{ value|filter_name:参数 }}
'|'左右没有空格没有空格没有空格
过滤器会把左边的值当做第一个参数传递给后面的过滤器,过滤器后面的值会当做第二个参数传递给过滤器
常用过滤器:
1.default
{{ value|default: "nothing"}}
如果value值没传的话就显示nothing
2.length:{{ value|length }}
返回value的长度,如 value=['a', 'b', 'c', 'd']的话,就显示4.
3.filesizeformat
将值格式化为一个 “人类可读的” 文件尺寸 (例如 '13 KB'
, '4.1 MB'
, '102 bytes'
, 等等)。例如:
{{ value|filesizeformat }}
如果 value 是 123456789,输出将会是 117.7 MB。
4.slice
切片
{{value|slice:"1:3"}}
从索引为1切到索引为3,不保留3,前闭后开,后面的参数可以为负数
5.date
格式化
{{ value|date:"Y-m-d H:i:s"}}
6.safe
Django的模板中会对HTML标签和JS等语法标签进行自动转义,原因显而易见,这样是为了安全。但是有的时候我们可能不希望这些HTML元素被转义,比如我们做一个内容管理系统,后台添加的文章中是经过修饰的,这些修饰可能是通过一个类似于FCKeditor编辑加注了HTML修饰符的文本,如果自动转义的话显示的就是保护HTML标签的源文件。为了在Django中关闭HTML的自动转义有两种方式,如果是一个单独的变量我们可以通过过滤器“|safe”的方式告诉Django这段代码是安全的不必转义。
比如:
value = "<a href='#'>点我</a>"
{{ value|safe}}
7.truncatechars
如果字符串字符多于指定的字符数量,那么会被截断。截断的字符串将以可翻译的省略号序列(“...”)结尾。
参数:截断的字符数
{{ value|truncatechars:9}}
其中...算3个字符位置
8.truncatewords
和truncatechars不同,这是按照空格的数量截断的,同样的。截断的字符串将以可翻译的省略号序列(“...”)结尾。
参数:截断的字符数
{{ value|truncatewords:3}}
其中...不算3个字符位置
自定义过滤器:
{% load my_tags %}
{{ num|baby:2 }}
{% s_tag 'w' 'a' 'd' %}