MTV与MVC(了解):

  MTV模型(Django用的就是MTV):

    M:模型层(models.py)

    T:templates

    C:views

  MVC模型:

    M:模型层(models.py)

    V:视图层(views.py)

    C:控制层(Controller)urls.py

  本质:Django的MTV本质上其实也是MVC

多对多表的三种创建方式:

  1、第一种Django orm自动帮我们创建

  1. class Book(models.Model):
  2. name = models.CharField(max_length=32)
  3. authors = models.ManyToManyField(to='Author')
  4.  
  5. class Author(models.Model):
  6. name = models.CharField(max_length=32)

    

  2、第二种手动创建第三张表

  3、第三种半自动创建第三张表

  1. class Book(models.Model):
  2. name = models.CharField(max_length=32)
  3. authors = models.ManyToManyField(to='Author', through='Book2Author', through_fields=('book', 'author'))
  4.  
  5. class Author(models.Model):
  6. name = models.CharField(max_length=32)
  7.  
  8. class Book2Author(models.Model):
  9. book = models.ForeignKey(to="Book")
  10. author = models.ForeignKey(to="Author")
  11. info = models.CharField(max_length=32)

  

前后端传输数据编码格式contentType:

  urlencoded:对应的数据格式:name=jason&password=666

    后端获取获取数据:request.POST

    ps:django会将urlencoded编码的数据解析自动放到request.POST

  formdata:

    form表单用来传输文件的编码格式

    后端获取文件格式的数据:request.FILES

    后端获取普通键值对的数据:request.POST

  application/json:

ajax:(https://www.cnblogs.com/Dominic-Ji/p/9234099.html)

   AJAX(Asynchronous Javascript And XML)翻译成中文就是“异步的Javascript和XML”。即使用Javascript语言与服务器进行异步交互,传输的数据为XML(当然,传输的数据不只是XML)。

  AJAX最大的优点就是在不重新加载整个页面的情况下,可以和服务器交换数据并更新部分网页的内容。(这一个特点给用户的感受是在不知不觉中就完成了请求和响应的过程)

  AJAX 不需要任何浏览器插件,但需要用户允许JavaScript在浏览器上执行。

  同步交互:客户端发出一个请求后,需要等地服务器响应结束后,才能发出第二个请求

  异步交互:客户端发出一个请求后,不需要等待服务器响应结束,就可以发出第二个请求

  前端朝后端发送请求的方式:

    1、浏览器手动输入网址  get请求

    2、a标签的form属性  get请求

    3、form表单  get/post请求(默认是get请求)

    4、ajax  get/post请求

  ajax简单用法

    ajax基本语法:

      必须有的四个东西:提交的地址url(可以不写,默认就是当前页面打开的地址)、提交的方式type、提交的数据data、回调函数success

    ajax默认传输数据的编码格式也是urlencoded

  1. $('#d1').click(function () {
  2. $.ajax({
  3. url: '/index/',
  4. type: 'post',
  5. data: {'name': 'william', 'password': '123'},
  6. success:function (data) {
  7. alert(data)
  8. }
  9. })
  10. })

  ajax传输json格式的数据

    application/json

    需要注意的点:

      编码与数据格式要一致

    前端:

  1. $('#d1').click(function () {
  2. $.ajax({
  3. url: '/index/',
  4. type: 'post',
  5. contentType: "application/json",
  6. data: JSON.stringify({"name": 'william', 'password': ''}),
  7. success:function (data) {
  8. alert(data)
  9. }
  10. })
  11. })

    后端:

  1. import json
  2.  
  3. data = request.body
  4. res = data.decode('utf-8')
  5. res = json.loads(res)

  ajax传输文件数据

    ajax传输文件必须借助于内置对象Formdata

    前端:

  1. $("#b1").click(function () {
  2. let formData = new FormData();
  3. formData.append('标签中的name', $('#i1')[0].files[0]);
  4. $.ajax({
  5. url: '',
  6. type: 'post',
  7. processData: false, // 告诉jquery不要去处理发送的数据
  8. contentType: false, // 告诉jquery不要去设置Content-Type请求头
  9. data: formData,
  10. success:function (data) {
  11. console.log(data)
  12. }
  13. })
  14. })

    后端:

  1. def upload(request):
  2. if request.method == 'POST':
  3. print(request.POST)
  4. file_obj = request.FILES.get('标签中的name')
  5. with open(file_obj.name, 'wb') as f:
  6. for chunk in file_obj.chunks():
  7. f.write(chunk)
  8. return HttpResponse('ok')
  9.  
  10. return render(request, 'upload.html')

    form表单与ajax的异同点:

      1、form表单不支持异步提交局部刷新

      2、form表单不支持传输json格式数据

      3、form表单与ajax默认传输数据格式都是urlencoded

批量插入数据:

  首先在外面创建一个列表用来保存数据对象,然后通过bulk_create()方法来直接将可迭代对象一次性插入到数据库中,节省了大量的时间

  1. l = []
  2. for i in range(10000):
  3. l.append(models.Book2(name='第%s本书' % i))
  4. models.Book2.object.bulk_create(l)

  

  

自定义分页器:

  1. current_page = request.GET.get('page', 1)
  2. page_obj = my_page.Pagination(current_page, all_count)
  3. page_queryset = book_list[page_obj.start:page_obj.end]

  页码的渲染通常都是单数,符合中国人的审美标准

  需要完善的:

    1、需要加上首页和尾页

  补充:

  1. <li><a href="?page=1">1</a></li> // href默认前面会自动补全

  

  

  

Django--多对多表的创建、contentType、ajax、ajax传输json数据格式、ajax传输文件数据、 自定义分页器的更多相关文章

  1. Django---CSRF的装饰器,CSRF的流程,JSON数据格式,ajax技术(基于JQ实现)

    Django---CSRF的装饰器,CSRF的流程,JSON数据格式,ajax技术(基于JQ实现) 一丶CSRF相关的装饰器 from django.utils.decorators import m ...

  2. Django多对多表的三种创建方式,MTV与MVC概念

    MTV与MVC MTV模型(django): M:模型层(models.py) T:templates V:views MVC模型: M:模型层(models.py) V:视图层(views.py) ...

  3. Django中ORM表的创建以及基本增删改查

    Django作为重量级的Python web框架,在做项目时肯定少不了与数据库打交道,编程人员对数据库的语法简单的还行,但过多的数据库语句不是编程人员的重点对象.因此用ORM来操作数据库相当快捷.今天 ...

  4. 一、Ajax 二、JSON数据格式 三、Ajax+Jquery 四、分页的实现

    一.Ajax概述###<1>概述 ###<2>组成 以XMLHttpRequest为核心,发送Ajax请求和接收处理结果 以javascript为语言基础 以XML/JSON作 ...

  5. Django 多对多表的三种创建方式

    第一种: class Book(models.Model): name = models.CharField(max_length=32) # 第一种自动创建 authors = models.Man ...

  6. Linux下开发python django程序(Form表单对象创建和使用)

    1.在setting.py文件中修改节点,注释掉其中一行 MIDDLEWARE_CLASSES = ( 'django.middleware.common.CommonMiddleware', 'dj ...

  7. 2019年6月14日 Web框架之Django_07 进阶操作(MTV与MVC、多对多表三种创建方式、前后端传输数据编码格式contentType、ajax、自定义分页器)

    摘要 MTV与MVC 多对多表三种创建方式 ajax ,前后端传输数据编码格式contentType 批量插入数据和自定义分页器 一.MVC与MTV MVC(Model View Controller ...

  8. Django框架第九篇--Django和Ajax、序列化组件(serializers)、自定义分页器、模型表choice参数

    Django和Ajax 一.什么是Ajax AJAX(Asynchronous Javascript And XML)翻译成中文就是“异步的Javascript和XML”.即使用Javascript语 ...

  9. 【笔记】Django的ORM之多对多表的增和删

    [笔记]Django的ORM之多对多表的增和删 Django ORM 多对多  一 昨日补充:外键关联 外键在ORM中的关联方式: 与数据表相关的类都放到models.py文件中 class Book ...

随机推荐

  1. Windows安全证书生成方法(开发者证书)

    首先,查看本机安装的证书可在“运行”中输入:certmgr.msc 一.win8.8.1.win10系统,使用管理员powershell创建证书: (1)利用如下命令来创建证书并获取到其指纹 New- ...

  2. 杂项-公司:Oracle

    ylbtech-杂项-公司:Oracle 甲骨文公司,全称甲骨文股份有限公司(甲骨文软件系统有限公司),是全球最大的企业级软件公司,总部位于美国加利福尼亚州的红木滩.1989年正式进入中国市场.201 ...

  3. 3. 单元测试框架(unittest)1——TestCase

    1. import unittest 引入unittest模块:   2. class SearchTest (unittest.TestCase): 定义一个继承于TestCase类的子类:   3 ...

  4. 可怜的baidu,可怜的音库

    baidu词典中用的中文音库竟然全都是汉典的中文音库   真可怜,baidu这么大个公司竟然连着1250个发音都懒得录   汉典的音库布都是同一格式,导致一部分音频文件MCI函数无法播放   真他妈可 ...

  5. vue 实现单选框

    参考:https://blog.csdn.net/qq_42221334/article/details/81630634 效果: vue: <template> <div> ...

  6. 大批量数据导出excel

    有次面试时,老板问我大批量数据一次性导出会有什么问题 感谢度娘提供,感谢原博主提供 https://www.cnblogs.com/zou90512/p/3989450.html

  7. 如何使用log4j记录日志

    1.下载jar包 http://logging.apache.org/log4j 2.将jar包加入项目 放在lib(没有就创建)下 对已经复制过来的jar包鼠标点击右键,选中BuildPath  - ...

  8. vector以及array和数组

    //比较数组.vector.array #include <iostream> #include <vector> #include <array> #includ ...

  9. csp-s模拟47 Emotional Flutter,Endless Fantasy题解

    题面:https://www.cnblogs.com/Juve/articles/11558523.html A:Emotional Flutter 如果起点确定,那么我们后面走的点都是固定的,及mo ...

  10. 关于MySQL IN LIKE OR使用索引的问题

    以前在网上看了一些资料,有些人说话不严谨,导致一直被误导,最近在实际开发中发现一些结论有问题,因此特地整理了一下,防止下次继续犯错. 以下前提是有对这个字段建立索引(简直废话,没建的肯定不会使用索引啊 ...