Django模板层
Django模板层
一、关于模板语法
针对需要加括号调用的名字,模板语法会自动加括号调用,只需要写名字就行
{{}} # 主要与数据相关
{%%} # 主要与逻辑相关
{##} # 模板语法的注释
模板语法传值
# 方式1:精准传值 不浪费资源 针对多资源的传递书写麻烦
return render(request,'demo02.html', {'n1':name, 'a1':age})
# 方式2:将函数名称空间中所有名字全部传递 名字过于多的时候有优势 但是会浪费资源
return render(request,'demo02.html', locals())
# 模板语法传值特性
1.基本数据类型正常展示
2.文件对象也可以用展示并调用方法
3.函数名会自动加括号执行并将返回值展示到页面上(不支持额外传参)
4.类名也会自动加括号调用对象则不会
二、模板层之标签
# if 条件语法
{% if 条件1(可以自己写也可以用传递过来的数据) %}
<p>今天又是周三了</p>
{% elif 条件2(可以自己写也可以用传递过来的数据) %}
<p>百日冲刺</p>
{% else %}
<p>没多少时间了!</p>
{% endif %}
# for循环
{% for k in t1 %}
{% if forloop.first %}
<p>这是我的第一次循环{{ k }}</p>
{% elif forloop.last %}
<p>这是我的最后一次循环{{ k }}</p>
{% else %}
<p>这是中间循环{{ k }}</p>
{% endif %}
{% empty %}
<p>你给我传的数据是空的无法循环取值(空字符串、空列表、空字典)</p>
{% endfor %}
django模板语法取值操作>>>:只支持句点符
{{ d1.hobby.2.a1 }} # 句点符既可以点索引也可以点键
{% with d1.hobby.2.a1 as h %} # 复杂数据获取之后需要反复使用可以起别名
<a href="">{{ h }}</a>
{% endwith %}
二、自定义过滤器、标签
如果想要自定义一些模板语法 需要先完成下列的三步走战略
1.在应用下创建一个名字必须叫templatetags的目录
2.在上述目录下创建任意名称的py文件
3.在上述py文件内先编写两行固定的代码
from django import template
register = template.Library()
# 自定义过滤器(最大只能接收两个参数)
@register.filter(name='myadd')
def func1(a, b):
return a + b
{% load mytags %}
<p>{{ i|myadd:1 }}</p>
# 自定义标签(参数没有限制)
@register.simple_tag(name='mytag')
def func2(a, b, c, d, e):
return f'{a}-{b}-{c}-{d}-{e}'
{% load mytags %}
{% mytag 'jason' 'kevin' 'oscar' 'tony' 'lili' %}
三、模板的继承与导入
模板的继承(重要):多个页面有很多相似的地方
有两种方式,如下
方式1:传统的复制粘贴
方式2:模板的继承
# 模板的继承具体操作
1.在模板中使用block划定子板以后可以修改的区域
{% block 区域名称 %}
{% endblock %}
2.子板继承模板
{% extends 'home.html' %}
{% block 区域名称 %}
子板自己的内容
{% endblock %}
模板中至少应该有三个区域:页面内容区、css样式区、js代码区
子板也可以继续使用模板的内容 {{ block.super }}
模板的导入:{% include 'myform.html' %}
四、模板层前期准备
自带的sqlite3数据库对时间字段不敏感 有时候会展示错乱
所以我们习惯切换成常见的数据库比如MySQL django orm并不会自动创建库
所以需要提前准备好
2.单独测试django某个功能层
默认不允许单独测试某个py文件如果想要测试某个py文件(主要models.py)
测试环境1:pycharm提供的python console
测试环境2:自己搭建(自带的test或者自己创建)
# 自己搭建测试环境方法步骤
1.先创建py文件(django自带的test文件也可以的)
2.拷贝manage.py前四行
3.自己再加以下两行代码
import django
django.setup()
django orm底层还是SQL语句 我们是可以查看的
如果我们手上是一个QuerySet对象 那么可以直接点query查看SQL语句
如果想查看所有orm底层的SQL语句也可以在配置文件添加日志记录