一、模板层之标签

分支结构if

  1. {% if 条件1(可以自己写也可以用传递过来的数据) %}
  2. <p>今天又是周三了</p>
  3. {% elif 条件2(可以自己写也可以用传递过来的数据) %}
  4. <p>百日冲刺</p>
  5. {% else %}
  6. <p>没多少时间了!</p>
  7. {% endif %}

for循环

for循环

  1. {% for k in t1 %}
  2. {% if forloop.first %}
  3. <p>这是我的第一次循环{{ k }}</p>
  4. {% elif forloop.last %}
  5. <p>这是我的最后一次循环{{ k }}</p>
  6. {% else %}
  7. <p>这是中间循环{{ k }}</p>
  8. {% endif %}
  9. {% empty %}
  10. <p>你给我传的数据是空的无法循环取值(空字符串、空列表、空字典)</p>
  11. {% endfor %}

for...empty

for循环中的用来遍历的变量,如果为空,就会触发empty执行,empty下的内容

forloop关键字

我们在for循环中使用forloop关键字可以打印当前for循环遍历到的数据的一些属性

for循环可用的一些参数:

for循环使用参数也是在forloop关键字的基础上使用的

Variable Description
forloop.counter 当前循环的索引值(从1开始)
forloop.counter0 当前循环的索引值(从0开始)
forloop.revcounter 当前循环的倒序索引值(从1开始)
forloop.revcounter0 当前循环的倒序索引值(从0开始)
forloop.first 当前循环是不是第一次循环(布尔值)
forloop.last 当前循环是不是最后一次循环(布尔值)
forloop.parentloop 本层循环的外层循环

其他小知识点

  • django模板语法取值操作>>>:只支持句点符
  • 句点符既可以点索引也可以点键
  1. {{ d1.hobby.2.a1 }}

with(定义变量名)

复杂数据获取之后需要反复使用可以起别名(但是起名有格式要求,不太方便也不实用)

  1. {% with d1.hobby.2.a1 as h %}
  2. <a href="">{{ h }}</a>
  3. {% endwith %}

二、自定义过滤器、标签及inclusion_tag(了解)

自定义一些模板语法的使用前提

如果想要自定义一些模板语法(如自定义过滤器、标签、inclusion_tag),需要满足下列三个前提条件。

​ 1.在应用下创建一个名字必须叫templatetags的目录

​ 2.在上述目录下创建任意名称的py文件

​ 3.在上述py文件内先编写两行固定的代码

  1. from django import template
  2. register = template.Library()

ps:这里的register变量名不能更换

自定义过滤器

自定义过滤器最多只能接收两个参数

  1. @register.filter(name='myadd')
  2. 这里的name是给自定义过滤器命名用的
  3. def func1(a, b):
  4. return a + b
  5. {% load mytags %}
  6. 这个mytags表示的是自定义的过滤器所在的文件名称,导入过滤器类似导模块
  7. <p>{{ i|myadd:1 }}</p>

自定义标签函数

标签函数不同于过滤器,参数没有限制

  1. @register.simple_tag(name='mytag')
  2. def func2(a, b, c, d, e):
  3. return f'{a}-{b}-{c}-{d}-{e}'
  4. {% load mytags %}
  5. {% mytag 'jason' 'kevin' 'oscar' 'tony' 'lili' %}

标签函数其实就是在处理数据的时候比过滤器多了一步,过滤器等于是直接返回结果给网页,而标签函数等于是将数据进行处理,再返回给网页

自定义inclusion_tag

inclusion_tag就是在一个新的网页上定义部分html代码,实现一定的功能,然后通过名称,可以被调用。

  1. views.py文件
  2. @register.inclusion_tag('menu.html',name='mymenu')
  3. def func3(n):
  4. html = []
  5. for i in range(n):
  6. html.append('<li>第%s页</li>'%i)
  7. return locals()
  8. menu.html文件
  9. <ul>
  10. {% for liStr in html %}
  11. {{ liStr|safe }}
  12. {% endfor %}
  13. </ul>
  14. indexPage.html文件body部分代码
  15. {% load mytags %}
  16. {% mymenu 20 %}

三、母版(模板)的继承与导入(重要)

使用环境

在实际开发中,网页文件彼此之间可能会有大量冗余代码,为此django提供了专门的语法来解决这个问题,主要围绕三种标签的使用:include标签、extends标签、block标签,详解如下:

针对不同网页文件出现大量相同代码的情况,我们可以使用两种方式来处理:

方式一:传统的复制粘贴

方式二:母版的继承

很明显,第一中方法太low了,所以咋们来展开说说母版的继承

首先我们需要创建一个网页,接下来的网页可以用它当模版,因此我们称他为母版。

1.在模板中使用block划定子板以后可以修改的区域

接着我们在母版内划定子板可以修改的内容,划定区域的代码如下 :

  1. {% block 区域名称 %}
  2. {% endblock %}

2.子板继承模板

  1. {% extends 'home.html' %}
  2. 这是子板继承母版的代码
  3. {% block 区域名称 %}
  4. 子板自己的内容
  5. {% endblock %}
  6. 这是子板自定义母版中可修改内容的代码

ps:模板中至少应该有三个区域

​ 页面内容区、css样式区、js代码区

  1. 1.css样式更改
  2. {% block css %}
  3. css样式
  4. {% endblock %}
  5. 2.content样式(页面内容)更改
  6. {% block content %}
  7. content 样式
  8. {% endblock %}
  9. 3.js样式更改
  10. {% block js %}
  11. js样式
  12. {% endblock %}

如果我们想在子板中使用母版的内容,需要用到下方代码

  1. {{ block.super }}

模版的导入(了解)

当我们在编写html代码的时候,也可以不适用母版,而是直接导入一部分html内容。

ps:导入的这个html文件不能是一个完整的html文件,内部只能有一部分功能。否则会出现冲突。

导入的代码如下:

  1. {% include 'myform.html' %}

四、模型层之前期准备

模型层的了解

模型(Model)负责业务是对象和数据库的关系映射(ORM),即对象关系映射。

ORM是“对象-关系-映射”的简称,主要任务是:

  1. 建立模型类和表之间的对应关系,允许我们通过面向对象的方式来操作数据库。
  2. 将对象、列表的操作,转换为sql语句。
  3. 根据设计的模型类生成数据库中的表格。
  4. 将sql查询到的结果转换为对象、列表

而我们的models.py主要负责程序中用于处理数据逻辑的部分(如数据的存取)。它包含你所储存数据的必要字段和行为。通常,每个模型对应数据库中唯一的一张表。

模型

我们知道了模型层的作用,你有没有想过模型是一个什么东西呢?下面带领大家一起来学习。

什么是模型?

  1. 模型是一个Python类,它是由django.db.models.Model派生出的子类。
  2. 一个模型类代表数据库的一张数据表。
  3. 模型类中的每一个属性都代表数据库中的一个字段。
  4. 模型是数据交互的接口,是表示和操作数据库的方法和方式。

模型层的前置知识点

为什么要将Django自带的sqlite3数据库替换成MySQL?

Django自带的sqlite3数据库对时间字段不敏感,有时候会展示错乱,所以我们习惯切换成常见的数据库比如MySQL。

ps:django的ORM并不会自动帮我们自动创建库,所以需要提前准备好。

如何单独测试Django的某个功能层

这里我们说的功能层,指代的就是代表某一层的py文件,通常来说别的功能层的py文件并不能单独测试,彼此都是有关联的。这里我们主要指代的还是模型层的my文件models.py。

默认情况下Django并不允许单独测试某个py文件

创建测试环境的方式一:

pycharm提供的python console

创建测试环境的方式二:

自己搭建(可以使用应用中自带的test.py文件或者自己创建一个新的py文件)

在打开对应的py文件后,先拷贝manage.py前四行

接着我们再添加两行代码

  1. import django
  2. django.setup()

django的orm底层还是SQL语句,我们是可以查看的。

临时查看的方法

如果我们手上是一个QuerySet对象 那么可以直接点query查看SQL语句

Django终端打印SQL语句

如果想查看所有orm底层的SQL语句也可以在配置文件添加日志记录

  1. LOGGING = {
  2. 'version': 1,
  3. 'disable_existing_loggers': False,
  4. 'handlers': {
  5. 'console':{
  6. 'level':'DEBUG',
  7. 'class':'logging.StreamHandler',
  8. },
  9. },
  10. 'loggers': {
  11. 'django.db.backends': {
  12. 'handlers': ['console'],
  13. 'propagate': True,
  14. 'level':'DEBUG',
  15. },
  16. }
  17. }

五、ORM常用关键字

1.create()

创建数据并直接获取当前创建的数据对象

  1. res = models.User.objects.create(name='阿兵', age=28)
  2. res = models.User.objects.create(name='oscar', age=18)
  3. res = models.User.objects.create(name='jerry', age=38)
  4. res = models.User.objects.create(name='jack', age=88)
  5. print(res)

2.filter()

根据条件筛选数据,结果是QuerySet [数据对象1,数据对象2]

  1. res = models.User.objects.filter()
  2. res = models.User.objects.filter(name='jason')
  3. res = models.User.objects.filter(name='jason', age=19) # 括号内支持多个条件但是默认是and关系

3.first()、last()

QuerySet支持索引取值但是只支持正数 并且orm不建议你使用索引

  1. res = models.User.objects.filter()[1]
  2. res = models.User.objects.filter(pk=100)[0] # 数据不存在索引取值会报错
  3. res = models.User.objects.filter(pk=100).first() # 数据不存在不会报错而是返回None
  4. res = models.User.objects.filter().last() # 数据不存在不会报错而是返回None

4.update()

更新数据(批量更新)

  1. models.User.objects.filter().update() 批量更新
  2. models.User.objects.filter(id=1).update() 单个更新

5.delete()

删除数据(批量删除)

  1. models.User.objects.filter().delete() 批量删除
  2. models.User.objects.filter(id=1).delete() 单个删除

6.all()

查询所有数据,结果是QuerySet [数据对象1,数据对象2]

  1. res = models.User.objects.all()

7.values()

根据指定字段获取数据,结果是QuerySet [{},{},{},{}]

  1. res = models.User.objects.all().values('name')
  2. res = models.User.objects.filter().values()
  3. res = models.User.objects.values()

8.values_list()

根据指定字段获取数据,结果是QuerySet [(),(),(),()]

  1. res = models.User.objects.all().values_list('name','age')

9.distinct()

去重 数据一定要一模一样才可以 如果有主键肯定不行

  1. res = models.User.objects.values('name','age').distinct()

10.order_by()

根据指定条件排序 默认是升序 字段前面加负号就是降序

  1. res = models.User.objects.all().order_by('age')
  2. print(res)

11.get()

根据条件筛选数据并直接获取到数据对象 一旦条件不存在会直接报错 不建议使用

  1. res = models.User.objects.get(pk=1)
  2. print(res)
  3. res = models.User.objects.get(pk=100, name='jason')
  4. print(res)

12.exclude()

取反操作

  1. res = models.User.objects.exclude(pk=1)
  2. print(res)

13.reverse()

颠倒顺序(被操作的对象必须是已经排过序的才可以)

  1. res = models.User.objects.all()
  2. res = models.User.objects.all().order_by('age')
  3. res1 = models.User.objects.all().order_by('age').reverse()
  4. print(res, res1)

14.count()

统计结果集中数据的个数

  1. res = models.User.objects.all().count()
  2. print(res)

15.exists()

判断结果集中是否含有数据 如果有则返回True 没有则返回False

  1. res = models.User.objects.all().exists()
  2. print(res)
  3. res1 = models.User.objects.filter(pk=100).exists()
  4. print(res1)

12月14日内容总结——模板层之标签、自定义模板语法、母版(模版)的继承与导入、模型层前期准备知识点、ORM常用关键字的更多相关文章

  1. 12月21日内容总结——forms组件渲染标签、展示信息、校验数据的一些补充,forms组件参数和源码剖析,modelform组件,Django中间件

    目录 一.forms组件渲染标签 二.forms组件展示信息 三.forms组件校验补充 四.forms组件参数补充 五.forms组件源码剖析 六.modelform组件 什么是modelform组 ...

  2. 12月14日《奥威Power-BI销售计划填报》腾讯课堂开课啦

           2016年的最后一个月也过半了,新的一年就要到来,你是否做好了启程的准备?新的一年,有计划,有目标,有方向,才不至于迷茫.规划你的2017,新的一年,遇见更好的自己!        所以 ...

  3. 2016年12月14日 星期三 --出埃及记 Exodus 21:9

    2016年12月14日 星期三 --出埃及记 Exodus 21:9 If he selects her for his son, he must grant her the rights of a ...

  4. 北京Uber优步司机奖励政策(12月14日)

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...

  5. 天津Uber优步司机奖励政策(12月14日到12月20日)

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...

  6. 南京Uber优步司机奖励政策(12月14日到12月20日)

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...

  7. 长沙Uber优步司机奖励政策(12月14日到12月20日)

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...

  8. 厦门Uber优步司机奖励政策(12月14日到12月20日)

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...

  9. 苏州Uber优步司机奖励政策(12月14日到12月20日)

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...

随机推荐

  1. django启动报错:DisallowedHost at /

    学习django第一天,第一次启动服务就报错,报错内容如下: DisallowedHost at / Invalid HTTP_HOST header: '192.168.116.22:8000'. ...

  2. (C++) C++ new operator, operator new 及 placement new (待整理)

    https://blog.csdn.net/songthin/article/details/1703966 https://cplusplus.com/reference/new/operator ...

  3. 解决"raise EnvironmentError("%s not found" % (_mysql_config_path,)) OSError: mysql_config not found"报错

    redhat系(如centos) yum install mysql-devel debain系(如ubuntu) sudo apt-get install libmysqlclient-dev

  4. 关于最新版本listen1 (2.1.6)的修改心得(添加下载功能)

    注:本文只作为技术交流 前言 再次感谢 listen1 的作者开发出如此强大的音乐播放器 项目地址 上一篇的文章没有解决跨域问题(命名不能正确命名), 上一篇文章 地址 这次解决了,并简单的美化了下载 ...

  5. 本地JS文件批量压缩

    最近在维护一个小后台项目,有段JS需要压缩上传到CDN存储服务器.由于之前压缩的JS文件都比较少,都是手动压缩的.这次需要压缩的文件比较多,所以用了批量压缩.特此记录一下,方便大家和自己以后再用到的时 ...

  6. JAVA里Map的一些常用方法

    Map的常用方法 案例1 场景:一张建行用户体验金信息大表(百万级别),里面存在一个字段对多条数据,需要统计某个字段的多条数据累加值以供于别的服务调用. 优化前解决:直接查出来一个大list给到另一个 ...

  7. ARC145~152 题解

    比赛标号从大到小排列 . 因为博主比较菜所以没有题解的题都是博主不会做的 /youl ARC144 以前的比赛懒得写了 . 目录 AtCoder Regular Contest 152 B. Pass ...

  8. (java 实现开箱即用基于 redis 的分布式锁

    项目简介 lock 为 java 设计的分布式锁,开箱即用,纵享丝滑. 开源地址:https://github.com/houbb/lock 目的 开箱即用,支持注解式和过程式调用 基于 redis ...

  9. 利用node快速生成脚本

    整理框架时突然发现两个文件从来没有使用过,删除的瞬间仿佛get到了用处. fs 可用于与文件系统进行交互模块 path 提供一些实用工具,用于处理文件和目录的路径 process.argv 返回一个数 ...

  10. CTF中RSA常见类型解法

    Python脚本 #十六进制转ASCII编码 import binascii print(binascii.unhexlify(hex(m)[2:])) #rsa import gmpy2 phi = ...