django框架模板层——标签、自定义过滤器、标签、inclusion_tag、继承与导入、外键字段、外键字段数据增删改查
一、模板层之标签
{% if 条件1(可以是自己写的条件,也可以是传递过来的条件) %}
<p>today is wednesday</p>
{% elif 条件2(可以是自己写的条件,也可以是传递过来的条件) %}
<p>Hundred Day Sprint!</p>
{% else %}
<P>No times</p>
{% endif %}
{% for k in t1 %}
{% if forloop.first %}
<p>This is my first circle</p>
{% elif forloop.last %}
<p>This is my last circle</p>
{% else %}
<p>This is my center circle</p>
{% endif %}
{% empty %}
<p>This data is empty,can not circle</p>
{% endfor %}
'''
django模板语法取值操作:只支持句点符,句点符既可以点索引也可以点键
{{ d1.hobby.2.a1 }}
复杂数据的获取之后,如果需要反复使用可以起别名
{{ with d1.hobby.2.a1 as h }}
<a href="">{{ h }}</a>
{% endwith %}
'''
二、自定义过滤器、标签及inclusion_tag
'''
如果想要自定义一些模板语法,需要完成下列的三步走战略
1、在应用下创建一个名叫templatetags的目录
2、在上述目录下创建任意名称的py文件
3、在上述py文件内先编写两行固定的代码
from django import template
register = template.Library()
'''
# 自定义过滤器(最大只能接收两个参数)
@register.filter(name='myadd')
def func(a,b):
return a + b
{% load mytags %}
<p>{{ i|myadd:1 }}</p>
# 自定义inclusion_tag(局部的html代码)
@register.inclusion_tag('menu.html',name='mymenu')
def func(n):
html = []
for i in range(n):
html.append('<li>%s line</li>'%i)
return locals()
{% load mytags %}
{% mymenu 20 %}
三、模板的继承与导入
'''
模板的继承:
多个页面有很多相似的地方,我们可以采取以下方式:
方式1:传统的复制粘贴
方式2:模板的继承
'''
# 在模板中使用block划定子板以后可以修改的区域
{% block 区域名称 %}
{% endblock %}
# 子板继承模板
{% extends 'home.html' %}
{% block 区域名称 %}
子板自己特有的内容
{% endblock %}
'''
模板中至少应该要有三个区域
页面内容区域、css样式区域、js代码区
子板也可以继续使用模板的内容
{{ block.super }}
'''
# 模板的导入(了解)
'''
将某个html 的部分提前写好,之后很多html页面想使用的时候都可以导入使用
'''
{% include 'myform.html' %}
四、模型层之前期准备
'''
1、自带sqlite3数据库对时间字段不敏感,有时候会展示错乱,所以我们习惯切换成常见的数据库,比如MySQL,django ORM并不会帮你创建库,所以需要我们提前准备好要使用的库
2、单独测试django的某个功能模块
默认不允许单独测试某个单独的py文件。
测试环境1:pycharm提供的python console
测试环境2:自己搭建
在自带的test.py文件或者自己创建一个py文件
1、copy manage.py 前四行
2、自己在添加两行
import django
django。setup()
3、django ORM底层还是SQL语句,我们可以查看
如果我们手上是一个QuerySet对象,那么我们嫩可以直接.query查看SQL语句
如果想查看所有ORM底层的SQL语言,也可以在配置中添加日志记录
'''
LOGGING = {
'version': 1,
'disable_existing_loggers': False,
'handlers': {
'console':{
'level':'DEBUG',
'class':'logging.StreamHandler',
},
},
'loggers': {
'django.db.backends': {
'handlers': ['console'],
'propagate': True,
'level':'DEBUG',
},
}
}
五、ORM常用关键字
# 1、create() 创建数据并直接获取当前创建的数据对象
res = models.User.objects.create()
# 2、filter() 根据条件筛选数据、结果是QuerySet [数据对象1,数据对象2,]
res = models.User.objects.filter() # 括号内不填默认全查
# 3、first(),last() QuerySet支持索引取值,但是支持正数,并且ORM不建议使用索引
res = models.User.objects.filter()[]
res = models.User.objects.filter(pk=100).first()# 数据不存在不会报错,返回None
res = models.User.objects.filter().last()
# 4、update() 批量更新数据
models.User.objects.filter().update()
# 5、delete() 批量删除数据
models.User.objects.filter().delete()
# 6、all() 查询所有数据,结果是QuerySet[数据对象1,数据对象2,]
res = models.User.objects.all()
# 7、values() 根据指定字段获取数据,结果是QuerySet[{},{},{}]
res = models.User.objects.all().values()
res = models.User.objects.filter().values()
# 8、value_list() 根据指定字段获取数据,结果是QuerySet[(),(),()]
res = models.User.objects.all().value_list()
# 9、distinct() 去重,数据一定要一模一样,注意不要带着主键
res = models.User.objects.values().distinct()
# 10、order_by() 根据指定条件排序,默认是升序,字段前面加-号就是降序
res = models.User.objects.all().order_by()
# 11、get() 根据条件筛选数据,并直接获取到数据对象,一旦条件不存在会直接报错,不建议使用
res = models.User.objects.get()
# 12、exclude() 取反操作
res = models.User.objects.exclude()
# 13、reverse() 颠倒顺序(被操作的对象必须是已经排序过的)
res = models.User.objects.all().order_by().reverse()
# 14、count() 统计结果集中数据的个数
res = models.User.objects.all().count()
# 15、exists() 判断结果集中是否含有数据,如果有返回True,没有返回False
res = models.User.objects.all().exists()
标签:自定义,models,标签,外键,django,objects,User,res,模板
From: https://www.cnblogs.com/HaiMan/p/16983833.html