功能
- 产生html,且不仅仅是一个html 包含:
- 静态内容:html,css,js
- 动态内容:模板语言
使用
- 一般使用 Django中提供的简写函数render调用模板
-
render(request,'XXX.html',{XX,XX})
模板语言(DTL)
-
变量
- 语法:{{ 变量 }}
- 变量名必须由字母、数字、下划线(不能以下划线开头)和点组成
- 解析顺序:当变量中有点.的时候 解析顺序如下:
- 把点前面的部分当成字典,点后面的当成key
- 把点前面的当成对象,点后面的当成属性
- 把点前面的当成对象,点后面的当成对象的方法
- 如果点后面数字,把点前面当成列表,点后面当成下标
- 都取不到值,就将变量设为空字符串
-
标签(tags)
- 语法:{% 代码段 %}
- for标签
- {%for item in 列表%}
- 循环逻辑
- {{forloop.counter}}表示当前是第几次循环,从1开始
- {%empty%}
- 列表为空或不存在时执行此逻辑
- {%endfor%}
- if标签
- {%for item in 列表%}
- 循环逻辑
- {{forloop.counter}}表示当前是第几次循环,从1开始
- {%empty%}
- 列表为空或不存在时执行此逻辑
- {%endfor%}
- for标签
- 比较运算符如下:==、!=、<、>、<=、>=
- 注意:运算符左右两侧必须有空格
- 布尔运算符如下:and、or、not
-
过滤器(filter)
- 对常量进行一些操作,可以用过滤器,语法如下:
-
变量|过滤器:参数
- 常用的过滤器有:date,default,length等,具体可参考Django文档
- 内置模板标签和过滤器 | Django 文档 | Djangohttps://docs.djangoproject.com/zh-hans/3.2/ref/templates/builtins/#ref-templates-builtins-filters
-
自定义模板标签和过滤器
- 共需要5步
- 在应用中创建templatetags目录。(添加
templatetags
模块后,需要重启服务器) - 在上面目录中创建__init__.py 和模块名.py 文件。(要自定义的 tags或filters模块)
- 导入模块,创建一个Library对象,用于装饰自定义的过滤器
from django import template register = template.Library()
- 编写自定义的函数,并用上面装饰器进行装饰注册。(函数至少接受1个最多接受2个参数)
@register.filter def XXX(num,[]): return XXX
- 在html模板中加载自定义的过滤器
{% load 模块名 %}
-
注释
- 在模板中使用模板注释,注释的代码不会被编译,不会输出到客户端;与html注释不同的是html注释只能注释html内容,不能注释模板语言,且会输出到客户端。
- 单行注释语法: {#...#}
- 多行注释使用comment标签,语法:{%comment%}
...
{%endcomment%}
模板继承
- 主要是为了提高代码重用,减轻开发人员的工作量
- 典型应用:网站的头部、尾部信息
父模板
- 如果发现在多个模板中复制一段代码,那就应该把这段内容定义到父模板中
- 标签block:用于在父模板中预留区域,留给子模板填充差异性的内容,名字不能相同
- 为了更好的可读性,建议给endblock标签写上名字,这个名字与对应的block名字相同
- 父模板中也可以使用上下文中传递过来的数据
{%block 名称%}
预留区域,可以编写默认内容,也可以没有默认内容
{%endblock 名称%}
子模板
- 标签extends:继承,写在子模板文件的第一行
{% extends "父模板名称.html"%}
- 子模版不用填充父模版中的所有预留区域,如果子模版没有填充,则使用父模版定义的默认值
- 填充父模板中指定名称的预留区域
{%block 名称%}
实际填充内容
{{block.super}}用于获取父模板中block的内容
{%endblock 名称%}
HTML转义
- 出于安全考虑,模板对上下文传递的字符串进行输出时,会对以下字符自动转义
小于号< 转换为<
大于号> 转换为>
单引号' 转换为'
双引号" 转换为 "
与符号& 转换为 &
-
关闭转义主要有2种方法:
- 单个变量可以用过滤器safe:{{变量|safe}}
- 设置一段代码都禁用转义,使用标签autoescape:接受on、off参数
{%autoescape off%}
...
{%endautoescape%}
CSRF
- CSRF全拼为Cross Site Request Forgery,译为跨站请求伪造。
- 重要信息如金额、积分等,采用POST方式传递
- 启用CSRF中间件,默认启用
- 在form表单中加入标签{% csrf_token %}
- 如果不个别视图关闭csrf验证可以用装饰器
-
from django.views.decorators.csrf import csrf_exempt @csrf_exempt def getip(request): pass
反向解析
-
作用:
- 从相应的 Django 视图标识以及要传递给它的参数来获取相关联的 URL
- 当一个url配置的地址发生改变时,页面上使用反向解析生成地址的位置不需要变化
-
实现步骤
- 在 项目/urls.py 中为include定义namespace属性
url(r'^',include('app.urls',namespace='app'))
- 在app/urls.py中 设置app名字
app_name = 'app'
- 在app/urls.py中为url定义name属性
url(r'^test/$', views.test,name='test')
- 在 项目/urls.py 中为include定义namespace属性
-
使用
- 在模板里:使用 url 模板标签。{%url 'namespace:name' [a[=x] b[=x]] %}
- 在 Python 编码:使用 reverse() 函数。reverse('namespace:name', kwargs={'a':x,'b':y})
- reverse 函数导入
from django.urls import reverse
- reverse 函数导入