模板语言
模板语言简称为DTL(Django Template Language)
模板变量
模板变量名由数字,字母,下划线和点组成,不能以下划线开头。
使用:{{模板变量名}}
def index2(request):
'''模板加载顺序'''
return render(request, 'booktest/index2.html')
# /temp_var
def temp_var(request):
'''模板变量'''
my_dict = {'title': '字典键值'}
my_list = [1, 2, 3]
book = BookInfo.objects.get(id=1)
#定义模板上下文
context={'my_dict':my_dict,'my_list':my_list,'book':book}
return render(request,'booktest/temp_var.html',context)
模板变量可以是字典,列表或者对象。定义好模板上下文之后,用render()函数传递给html
模板变量使用字典属性:{{ my_dict.title }}
使用列表元素:{{ my_list.1 }}
使用对象属性:{{ book.btitle }}
可以看到模板变量都是通过 . 调用的。
模板标签
模板标签background-color: red;
}
.yellow{
background-color: yellow;
}
.green{
background-color: green;
}
{% for book in books %}
{% if book.id <= 2 %}
{{ forloop.counter }}--{{ book.btitle }}{% elif book.id >= 5 %}
{{ forloop.counter }}--{{ book.btitle }}{% else %}
{{ forloop.counter }}--{{ book.btitle }}{% endif %}
{% endfor %}
具体的其他的模板标签可以参考Django官方文档。
过滤器
过滤器用于对模板变量进行操作
date:改变日期的显示格式
length:求长度,字符串,列表,元祖,字典
default:设置模板变量的默认值
格式:模板变量 | 过滤器:参数
date过滤器
{{ book.btitle }}--{book.bpub_date | date:'Y年-m月-d日'}default过滤器
{{dd | default:'无'}}
模板注释
单行注释:{# 注释 #}
多行注释:{% comment %}
模板继承
不同页面可能有相同的模块,这时候可以使用模板继承减少代码量
base.html内容
父模板导航条
{% block b1 %}
这是父模板b1块中的内容
{% endblock b1 %}
版权信息
child.html内容
{% extends 'booktest/base.html' %}
{% block b1 %}
{{ block.super }}
这是子模板b1的内容
{% endblock b1 %}
在父模板中{% block b1 %}
这是父模板b1块中的内容
{% endblock b1 %}定义一个预留快,预留块中可以有内容。子模板继承时,{% extends 'booktest/base.html' %}导入,{% block b1 %} {{ block.super }}
这是子模板b1的内容
{% endblock b1 %}写预留块,{{ block.super }}继承预留快的内容。html转义
通过render()函数传递过来的模板上下文默认是转义的,也就是说我们想传递html语言的时候,实际上传递过来的是字符串,这个时候我们可以通过过滤器关闭转义
{{context | safe}}