变量的使用:
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}}
如果字符串字符多于指定的字符数量,那么会被截断。截断的字符串将以可翻译的省略号序列(“...”)结尾。
参数:截断的字符数
{{ value|truncatechars:9}} 其中...算3个字符位置和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 '文件名'%}
转载于:https://www.cnblogs.com/98WDJ/p/10718234.html
相关资源:JAVA上百实例源码以及开源项目