目录
一、什么是Ajax
二、Ajax引入
案例
小结
三、前后端数据传输的编码格式(contentType)
【1】form表单
【2】编码格式
【3】Ajax
【4】代码演示
四、Ajax发送JSON格式数据
【1】引入
【2】后端
【3】总结
五、Ajax提交文件数据
【发送文件数据的格式】
【结论】
六、Ajax结合layer弹窗实现二次确认
七、批量插入数据
【1】项目需求
【2】解决方案
AJAX 不是新的编程语言,而是一种使用现有标准的新方法
场景:
优点:
def ab_ajax(request):
# if request.is_ajax():
if request.method=='POST':
'''接收ajax提交过来的数据'''
#
print(request.POST)
# d1 = request.POST.get('inp1') # str
# d2 = request.POST.get('inp2') # str
# d3 = int(d1) + int(d2)
# 序列化
import json
# json.dumps(d3)
user_dict = {"username":"kevin", "password":123}
# return HttpResponse(json.dumps(d3))
return HttpResponse(json.dumps(user_dict))
# return JsonResponse(user_dict)
return render(request, 'ab_ajax.html')
(1)基本语法
(2)注意
(3)HttpResponse 解决方式
前后端传输数据的格式
urlencoded
formdata
json
text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7
Accept-Encoding:gzip, deflate, br
Accept-Language:zh-CN,zh;q=0.9,en;q=0.8
Cache-Control:no-cache
Connection:keep-alive
Content-Length:27
Content-Type:application/x-www-form-urlencoded
username=22222&password=99
Accept:*/*
Accept-Encoding:gzip, deflate, br
Accept-Language:zh-CN,zh;q=0.9,en;q=0.8
Cache-Control:no-cache
Connection:keep-alive
Content-Length:31
Content-Type:application/x-www-form-urlencoded; charset=UTF-8
username=kevin&password=1314521
username=kevin&password=1314521
def index(request):
if request.method == 'POST':
print(request.POST)
print(request.FILES)
return render(request, 'index.html')
前后端传输数据的时候一定要保证编码格式数据与真正的数据格式是一致的
def ab_json(request):
if request.method == 'POST':
print(request.POST) #
return render(request, 'ab_json.html')
{"username":"kevin","password":521521}
def ab_json(request):
if request.method == 'POST':
print(request.POST) #
return render(request, 'ab_json.html')
Django针对JSON格式的数据不会做任何处理
针对JSON格式的数据需要自己手动处理
解决办法
def ab_json(request):
print(request.is_ajax()) # True
if request.method == 'POST':
print(request.POST) #
print(request.body) # 返回的是二进制数据 :b'{"username":"dream","password":521521}'
# 针对JSON格式的数据需要自己手动处理
json_bytes = request.body
# (1)方式一:先解码 再转换数据格式
json_str = json_bytes.decode('utf-8')
json_dict = json.loads(json_str)
print(json_dict, type(json_dict)) # {'username': 'dream', 'password': 521521}
# (2)方式二:json.loads(二进制数据) 内部可以自动解码再反序列化
json_dict_loads = json.loads(json_bytes)
print(json_dict_loads, type(json_dict_loads)) # {'username': 'dream', 'password': 521521}
return render(request, 'ab_json.html')
【补充】request方法判断ajax
request.is_ajax()
print(request.is_ajax())
正常浏览器网址回车提交的是 GET 请求 - 结果是False
当我们发送ajax请求后 - 结果是True
// 不指定参数,默认就是 urlencoded
contentType: 'application/json',
发送的数据一定要符合JSON格式
或经过JSON序列化再传输
request.body
中的数据通过Ajax传过来的数据是二进制数据
在request.body中
要经过自己的反序列化才能拿到我们想要的数据
Ajax发送文件数据需要借助js内置对象formdata
前端
username:
password:
file:
def ab_file(request):
if request.is_ajax():
if request.method == 'POST':
print('POST::>>', request.POST)
# 普通键值对放在了 request.POST 中
# POST::>>
print('FILES::>>', request.FILES)
# 文件数据放在了 request.FILES 中
# FILES::>> ]}>
return render(request, 'ab_file.html')
// 点击按钮向后端发送普通键值对数据和文件数据
$("#btn").on('click', function () {
// (1)先生成一个内置对象
let formDataObj = new FormData();
// (2)支持添加普通的键值对
formDataObj.append('username', $("#d1").val());
formDataObj.append('password', $("#d2").val());
// (3)支持添加文件对象 ---> 先拿到标签对象 ----> 再拿到文件对象
formDataObj.append('myfile', $("#d3")[0].files[0]);
// (4)基于Ajax,将文件对象发送给后端
$.ajax({
url: '',
type: 'post',
// 直接将对象放到data里面即可
data: formDataObj,
// Ajax发送文件必须添加的两个参数
// 不需要使用任何编码 - Django后端能自动识别 formdata 对象
contentType: false,
// 告诉浏览器不要对我的数据进行任何处理
processData: false,
success: function (args) {
}
})
FormData
// (1)先生成一个内置对象
let formDataObj = new FormData();
// (2)支持添加普通的键值对
formDataObj.append('username', $("#d1").val());
formDataObj.append('password', $("#d2").val());
// (3)支持添加文件对象 ---> 先拿到标签对象 ----> 再拿到文件对象
formDataObj.append('myfile', $("#d3")[0].files[0]);
// Ajax发送文件必须添加的两个参数
// 不需要使用任何编码 - Django后端能自动识别 formdata 对象
contentType: false,
// 告诉浏览器不要对我的数据进行任何处理
processData: false,
FormData
对象
request.POST
中request.FILES
中print('POST::>>', request.POST)
# 普通键值对放在了 request.POST 中
# POST::>>
print('FILES::>>', request.FILES)
# 文件数据放在了 request.FILES 中
# FILES::>> ]}>
layer 弹出层组件 - jQuery 弹出层插件
bulk_list = []
for i in range(10000):
user_obj=models.UserInfo(username='kevin%s' %i)
bulk_list.append(user_obj)
# 循环之后得到了一个列表,10000个对象
# 数据库的优化, 同样的功能,不同的sql执行的效率差距很大
# 优化查询速度的时候,首先想到的是,加索引、优化sql语句,有的sql走做引、有的sql不走索引
models.UserInfo.objects.bulk_create(bulk_list)