django-模型层之ajax续、批量插入、分页器
2021-02-11 16:18
标签:用户表 定义 响应 tmp 后端 content end 就是 time django-模型层之ajax续、批量插入、分页器 标签:用户表 定义 响应 tmp 后端 content end 就是 time 原文地址:https://www.cnblogs.com/wgwg/p/13040633.html今日内容概要
今日内容详细
前后端传输数据的编码格式(contentType)
1 # 我们主要研究post请求数据的编码格式
2 """
3 get请求数据就是直接放在url后面的
4 url?username=jason&password=123
5 """
6
7 # 可以朝后端发送post请求的方式
8 """
9 1.form表单
10 2.ajax请求
11 """
12
13
14 """
15 前后端传输数据的编码格式
16 urlencoded
17
18 formdata
19
20 json
21 """
22 # 研究form表单
23 默认的数据编码格式是urlencoded
24 数据格式:username=jason&password=123
25 django后端针对符合urlencoded编码格式的数据都会自动帮你解析封装到request.POST中
26 username=jason&password=123 >>> request.POST
27
28 如果你把编码格式改成formdata,那么针对普通的键值对还是解析到request.POST中而将文件解析到request.FILES中
29
30 form表单是没有办法发送json格式数据的
31
32
33 # 研究ajax
34 默认的编码格式也是urlencoded
35 数据格式:username=jason&age=20
36 django后端针对符合urlencoded编码格式的数据都会自动帮你解析封装到request.POST中
37 username=jason&age=20 >>> request.POST
ajax发送json格式数据
1 """
2 前后端传输数据的时候一定要确保编码格式跟数据真正的格式是一致的
3 不要骗人家!!!
4
5 {"username":"jason","age":25}
6 在request.POST里面肯定找不到
7
8 django针对json格式的数据 不会做任何的处理
9
10 request对象方法补充
11 request.is_ajax()
12 判断当前请求是否是ajax请求 返回布尔值
13
14 """
15
16 29
30 json_bytes = request.body # 获取浏览器发送过来的原生的二进制数据
31 json_str = json_bytes.decode(‘utf-8‘)
32 json_dict = json.loads(json_str)
33
34 # json.loads括号内如果传入了一个二进制格式的数据那么内部自动解码再反序列化
35 json_dict = json.loads(json_bytes)
36
37 """
38 ajax发送json格式数据需要注意点
39 1.contentType参数指定成:application/json
40 2.数据是真正的json格式数据
41 3.django后端不会帮你处理json格式数据需要你自己去request.body获取并处理
42 """
ajax发送文件
1 """
2 ajax发送文件需要借助于js内置对象FormData
3
4 """
5 32
33 def ab_file(request):
34 if request.is_ajax():
35 if request.method == ‘POST‘:
36 print(request.POST)
37 print(request.FILES)
38 return render(request,‘ab_file.html‘)
39
40 """
41 总结:
42 1.需要利用内置对象FormData
43 // 2 添加普通的键值对
44 formDateObj.append(‘username‘,$(‘#d1‘).val());
45 formDateObj.append(‘password‘,$(‘#d2‘).val());
46 // 3 添加文件对象
47 formDateObj.append(‘myfile‘,$(‘#d3‘)[0].files[0])
48 2.需要指定两个关键性的参数
49 contentType:false, // 不需使用任何编码 django后端能够自动识别formdata对象
50 processData:false, // 告诉你的浏览器不要对你的数据进行任何处理
51 3.django后端能够直接识别到formdata对象并且能够将内部的普通键值自动解析并封装到request.POST中 文件数据自动解析并封装到request.FILES中
52 """
django自带的序列化组件(前后端分离)(drf做铺垫)
1 """
2 如果发现你可以直接使用MySQL但是无法使用sqlite3
3 不要慌张不要恐惧 你只需要按照之前MySQL的操作将sqlite3的驱动装一下即可
4 """
5 # 需求:在前端给我获取到后端用户表里面所有的数据 并且要是列表套字典
6 import json
7 from django.http import JsonResponse
8 from django.core import serializers
9 def ab_ser(request):
10 user_queryset = models.User.objects.all()
11 # [{},{},{},{},{}]
12 # user_list = []
13 # for user_obj in user_queryset:
14 # tmp = {
15 # ‘pk‘:user_obj.pk,
16 # ‘username‘:user_obj.username,
17 # ‘age‘:user_obj.age,
18 # ‘gender‘:user_obj.get_gender_display()
19 # }
20 # user_list.append(tmp)
21 # return JsonResponse(user_list,safe=False)
22 # return render(request,‘ab_ser.html‘,locals())
23
24 # 序列化
25 res = serializers.serialize(‘json‘,user_queryset)
26 """会自动帮你将数据变成json格式的字符串 并且内部非常的全面"""
27 return HttpResponse(res)
28 """
29 [
30 {"pk": 1, "username": "jason", "age": 25, "gender": "male"},
31 {"pk": 2, "username": "egon", "age": 31, "gender": "female"},
32 {"pk": 3, "username": "kevin", "age": 32, "gender": "others"},
33 {"pk": 4, "username": "tank", "age": 40, "gender": 4}
34 ]
35 前后端分离的项目
36 作为后端开发的你只需要写代码将数据处理好
37 能够序列化返回给前端即可
38 再写一个接口文档 告诉前端每个字段代表的意思即可
39
40
41 [
42 { "model": "app01.user",
43 "pk": 1,
44 "fields": {"username": "jason", "age": 25, "gender": 1}},
45
46 { "model": "app01.user",
47 "pk": 2,
48 "fields": {"username": "egon", "age": 31, "gender": 2}},
49
50 { "model": "app01.user",
51 "pk": 3,
52 "fields": {"username": "kevin", "age": 32, "gender": 3}},
53
54 { "model": "app01.user",
55 "pk": 4,
56 "fields": {"username": "tank", "age": 40, "gender": 4}}
57 ]
58 写接口就是利用序列化组件渲染数据然后写一个接口文档 该交代交代一下就完事
59 """
ajax结合sweetalert
1 """
2 要学会如何拷贝
3 学会基于别人的基础之上做修改
4 研究各个参数表示的意思 然后找葫芦画瓢
5 """
6 53
54
55
56 import time
57 from django.http import JsonResponse
58 def delete_user(request):
59 """
60 前后端在用ajax进行交互的时候 后端通常给ajax的回调函数返回一个字典格式的数据
61 :param request:
62 :return:
63 """
64 if request.is_ajax():
65 if request.method == ‘POST‘:
66 back_dic = {"code":1000,‘msg‘:‘‘}
67 time.sleep(3) # 模拟操作数据的延迟
68 delete_id = request.POST.get(‘delete_id‘)
69 models.User.objects.filter(pk=delete_id).delete()
70 back_dic[‘msg‘] = ‘数据已经删了,你赶紧跑路!‘
71 # 我们需要告诉前端我们操作的结果
72 return JsonResponse(back_dic)
批量插入
1 def ab_pl(request):
2 # 先给Book插入一万条数据
3 # for i in range(10000):
4 # models.Book.objects.create(title=‘第%s本书‘%i)
5 # # 再将所有的数据查询并展示到前端页面
6 book_queryset = models.Book.objects.all()
7
8 # 批量插入
9 # book_list = []
10 # for i in range(100000):
11 # book_obj = models.Book(title=‘第%s本书‘%i)
12 # book_list.append(book_obj)
13 # models.Book.objects.bulk_create(book_list)
14 """
15 当你想要批量插入数据的时候 使用orm给你提供的bulk_create能够大大的减少操作时间
16 :param request:
17 :return:
18 """
19 return render(request,‘ab_pl.html‘,locals())
分页器
1 """
2 总数据100 每页展示10 需要10
3 总数据101 每页展示10 需要11
4 总数据99 每页展示10 需要10
5
6 如何通过代码动态的计算出到底需要多少页?
7
8
9 在制作页码个数的时候 一般情况下都是奇数个 符合中国人对称美的标准
10 """
11 # 分页
12 book_list = models.Book.objects.all()
13
14 # 想访问哪一页
15 current_page = request.GET.get(‘page‘,1) # 如果获取不到当前页码 就展示第一页
16 # 数据类型转换
17 try:
18 current_page = int(current_page)
19 except Exception:
20 current_page = 1
21 # 每页展示多少条
22 per_page_num = 10
23 # 起始位置
24 start_page = (current_page - 1) * per_page_num
25 # 终止位置
26 end_page = current_page * per_page_num
27
28 # 计算出到底需要多少页
29 all_count = book_list.count()
30
31 page_count, more = divmod(all_count, per_page_num)
32 if more:
33 page_count += 1
34
35 page_html = ‘‘
36 xxx = current_page
37 if current_page :
38 current_page = 6
39 for i in range(current_page-5,current_page+6):
40 if xxx == i:
41 page_html += ‘
作业
"""
必做
1.整理今日内容到博客
2.熟练掌握ajax发送json数据和文件数据代码
3.自己完成按钮的二次确认操作(ajax+sweetalert)
4.尝试理解自定义分页器逻辑,自己推导出简易版本代码
选做
1.阅读博客,预习自定义分页器封装版本使用方式
"""
下一篇:HTTPS 协议