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个字符位置


自定义过滤器:
必须做下面三件事:

1.必须在应用下新建一个名为templatetags的文件夹

2.在该文件夹下创建一个任意名的py文件

3.在该文件内必须先写下面两句话

from django import template

register=template.Library()
 
定义过滤器:
@register.filter(name='baby')
def my_sum(a,b)
return a+b
自定义标签:
@register.sumple_tag(name='plus')
def plus(a,b,c):
return '%s-%s-%s'
使用方法:
{% load my_tags %}
{{ num|baby:2 }}
{% s_tag 'w' 'a' 'd' %}
{{}}变量相关
{%%}逻辑相关
注意:自定义的过滤器可以在if和for中使用,但是自定义的标签不能使用
 
自定义inclusion_tag:
调用自定义的inclusion_tag能够返回一段html代码、
比如form表单,表格,列表
通常用于动态生成的HTML页面
自定义inclusion_tag
@register.inclusion_tag('login.html')
def get_html(n):
l=[]
for i in range(n):
i.append('第%项'%i)
return {'l':l}
 
模板的继承和导入:
在模板中指定一片区域命名为content
   
{% extends 'home.html'%} 引用home页面
{% block content%}
{%endblock%}
 
调用主页面的代码:
 
 
模板的继承:
需要在你的主页面通过block划定一片区域,给继承了主页面的子页面选择使用哪片区域
模板里面定义的块越多,可扩展性越高
 
通常情况下都有三块区
css
content
js
 
模板的导入:
应用场景:花了好长时间搭建了一个特别好看的某一个区域
使用方式:
{%include '文件名'%}
 
 

 

posted @ 2019-05-06 08:36 777ijBGly- 阅读(...) 评论(...) 编辑 收藏