Django框架详解之template

时间:2023-03-09 05:24:41
Django框架详解之template

模板简介

  将页面的设计和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 %}