15 Ajax技术

添加新博客 编辑本博客

yuan先生博客

一、简介

特点

  • 异步请求
  • 局部刷新

二、Ajax的实现

jQuery实现Ajax

  • url:请求的URL
  • type:请求方式
  • data:请求发送的数据,type为get数据会拼接到url中
  • success:请求成功后执行的回调函数

Form实现文件上传

  • form表单的enctype类型设置成multipart/form-data数据类型

Django获取上传的文件对象:

file=request.FILES

def fileput(request):
    if request.method=="GET":
        return render(request,'fileput.html')
    else:
        data=request.POST
        file=request.FILES
        file_obj=file.get('avatar')
        file_name=file_obj.name
        with open(file_name,'wb') as f:
            for line in file_obj:
                f.write(line)
        return HttpResponse('ok')
View Code

contentType头类型

form表单:

  • application/x-www-form-urlencoded:默认,只能上传字符串
  • multipart/form-data:上传文件

ajax:

  • application/x-www-form-urlencoded:默认值,只能上传字符串
  • application/json :发送json数据

Ajax发送json数据

前端ajax

$("input[type=button]").click(function () {
        $.ajax({
            url:'login/',
            type:'post',
            contentType:'application/json',
            data:JSON.stringify({
                a:1,
                b:2
            }),
            success:function (data) {
                console.log(data)
            }
        })
    });
View Code

Django后端

request.POST只有当contentType=urlencoed时才有数据

request.body 请求报文中的请求体

def login(request):
    print(request.body)
    print(request.POST)
View Code

前端用urlencoded编码时,django的request.body一样还是有数据

$("input[type=button]").click(function () {
        $.ajax({
            url:'login/',
            type:'post',
            //contentType:'application/json',
            data:{
                a:1,
                b:2
            },
            success:function (data) {
                console.log(data)
            }
        })
    });
View Code

也就是只有contentType为urlencoed时,才会将request.body内容解析成字典request.POST

 Ajax文件上传

ajax前端

//ajax文件上传
    $("input[type=button]").click(function () {
        var formdata=new FormData();//固定格式创建formData
        formdata.append("user",$("#user").val());//append方法添加键值对
        file=$("#avatar")[0].files[0];//获取文件对象
        formdata.append("avatar",file);//添加文件键值对
        $.ajax({
            url:'fileput/',
            type:'post',
            contentType:false,//对数据不做预处理,不做任何编码,编码交由FormData处理
            processData:false,
            data:formdata,
            success:function (data) {
                console.log(data)
            }
        })
    })
View Code

django后端和form表单一样,获取request.FILES对象

 

posted @ 2018-07-16 08:24  丫丫625202  阅读(173)  评论(0编辑  收藏  举报