模板简介
将页面的设计和python的代码分离开会更干净简洁更容易维护。我们可以使用Django的模板系统来实现这种模式
python的模板:HTML代码+模板语法
模板包括在使用时会被值替换掉的变量,和控制模板逻辑的标签
变量
在Django模板中遍历复杂数据结构的关键是句点字符
{#语法#} {{ var_name }}
views
def index(request):
import datetime
s='hello'
l=[1,2,3]
dic={"name":'lary',"age":18}
date = datetime.date(2000,3,12)
class Person(object):
def __init__(self,name):
self.name = name
person_l=Person("lily")
person_j=Person('jerry')
person_t=Person('tom')
person_li=[person_l, person_j, person_t]
return render(request,'index.html',{"l":l,"dic":dic,"date":date,"person_list":person_li,"s":s})
template
<body>
<h4>{{ s }}</h4>
<h4>{{ l.0 }}</h4>
<h4>{{ dic.name }}</h4>
<h4>{{ date.year }}</h4>
<h4>{{ person_list.0.name}}</h4>
{#句点符也可以用来引用对象的方法(无参数方法)#}
<h4>{{ dic.name.upper }}</h4>
模板之过滤器
语法
{{obj|filter_name:param}}
default
如果一个变量是false或者为空,使用给定的默认值。否则,使用变量的值
{{value|default:"nothing"}}
length
返回值的长度。它对字符串和列表都起作用
{{value|length}}
filesizeformat
将值格式化为一个可读的文件尺寸
{{value|filesizeformat}}
date
{#如果value=datetime.datetime.now()#}
{{value|date:"Y-m-d"}}
slice
{#如果value="hello world"#}
{{value|slice:"2:-1"}}
truncatechars
如果字符串多于指定的字符数量,那么会被截断。截断的字符串将以省略号(“...”)结尾
{{value|truncatechars:9}}
safe
Django模板中会对HTML标签和js等语法进行自动转义,这样是为了安全。但是有的时候我们可能不希望这些HTML元素被转义,为了在Django中关闭HTML的自动转义的两种方式,如果是一个单独的变量可以通过"|safe"的方式告诉Django这段代码是安全的不必转义
value="<a href="">点击</a>"
{{value|safe}}
autoescape
控制当前的自动转义行为,此标记采用on或者off作为参数,并确定自动转义是否在块内有效。该块以endautoescape结束标签关闭
def generate_report(request):
report_name = "this is a test report"
report_tilte = "<h1>this is a title</h1>"
return render(request, 'report.html', locals())
开启转义
{% autoescape on %}
{{ report_title }}
{% endautoescape %}
关闭转义,默认该语句块中的内容是安全的
{% autoescape off %}
{{ report_title }}
{% endautoescape %}
模板之标签
标签比变量更加复杂:一些在输出中创建文本,一些通过循环或逻辑来控制流程,一些加载其后的变量将使用到额外信息到模板中,一些变迁需要开始和结束标签
for标签
{#遍历每一个元素#}
<h4>{{ dic.name.upper }}</h4>
{% for person in person_list %}
<p>{{ person.name }}</p>
{% endfor %}
{#遍历字典#}
{% for key,val in dic.items %}
<p>{{ key }}:{{ val }}</p>
{% endfor %}
{#循环序号#}
{{forloop.counter}}
for...empty
for标签带有一个可选的{% empty%}从句,以便在给出的组是空的或者没有被找到时,可以有所操作
{#for empty#}
{% for person in person_list %}
<p>{{ person.name }}</p>
{% empty %}
<p>sorry,no person here</p>
{% endfor %}
if标签
if标签会对一个变量求值,如果它的值是true,对应的内容块会输出
{#if标签#}
{% if num > 100 or num < 0 %}
<p>无效</p>
{% elif num > 80 and num < 100 %}
<p>优秀</p>
{% else %}
<p>一般</p>
{% endif %}
with
使用一个简单的名字缓存一个复杂的变量,当你需要使用一个方法很多次的时候是非常有用的
{#with标签#}
{% with total=business.employees.count %}
{{ total}}employee{{ tatal|pluralize }}
{% endwith %}
csrf_token
这个标签用于跨站请求伪造保护
{#csrf_token#}
{% csrf_token %}
自定义标签和过滤器
在settings中的INSTALLED_APPS配置当前app
在app中创建templatetags模块
创建任意.py文件,如my_tags.py
from django import template
from django.utils.safestring import mark_safe
register = template.Library()
@register.filter
def filter_multi(x,y):
return x*y
@register.simple_tag
def simple_tag_multi(x,y):
return x*y
@register.simple_tag
def my_input(id,args):
result="<input type='text' id='%s' class='%s'/>"%(id,args,)
return mark_safe(result)
在使用自定义simple_tag和fileter的html文件中导入之前创建的my_tag.py
{% load my_tag %}
使用simple_tag和filter
{{ num|filter_multi:2 }}
{{ num|filter_multi:"[22,33,444]" }}
{#参数不限,但不能放在if for语句中#}
{% simple_tag_multi 2 5 %}
{% simple_tag_multi num 5 %}
{#filter可以用在if等语句后,simple_tag不可以#}
{% if num|filter_multi:30 > 100 %}
{{ num|filter_multi:30 }}
{% endif %}