ajax formdata 获取表单数据,jQuery Ajax使用FormData上传文件和其他数据后端web.py获取...

XMLHttpRequest Level 2 添加了一个新的接口——FormData。与普通的 Ajax 相比,使用 FormData 的最大优点就是我们可以异步上传二进制文件。

jQuery 2.0+的版本支持FormData

方法一:使用

表单初始化FormData对象方式上传文件

•前端(JQuery):

function loadFile(file){

var formdata = new FormData($$('form')[0]);

$.ajax({

url: 'jobs/add',

type: 'POST',

datatype: 'json',

data: formdata,

cache:false,

traditional: true,

contentType: false,

processData: false,

success: function (data) {},

error: function () {}

});

}

•后台(web.py):

class Add:

def POST(self):

i = web.input(myfile={})

print(i['myfile'].filename) #文件名

print(i['myfile'].value) #文件内容

print(i['myfile'].file.read()) #文件内容

注意:

1.

的enctype属性需要设置为“multipart/form-data”

2.$.ajax中processData、contentType和cache需要设置为false

3.后端通过web.input获取文件的字段名,同前端指定的input标签的name属性

方法二√:不用

,使用FormData对象添加字段方式上传文件

有时,我们并不想用

标签,而且通过ajax传给后端的并不只有文件,可能还有其他的键值对,这时就可以用这个方法

•前端(JQuery):

function loadFile(file){

container.fd = new FormData();

container.fd.append('myfile',file);

container.fd.append('otherkey',othervalue);

$.ajax({

url: 'jobs/add',

type: 'POST',

datatype: 'json',

data: fd,

cache:false,

traditional: true,

contentType: false,

processData: false,

success: function (data) {},

error: function () {}

});

}

•后台(web.py):

class Add:

def POST(self):

i = web.input(myfile={}, otherkey='')

print(i['myfile'].filename) #文件名

print(i['myfile'].value) #文件内容

print(i['myfile'].file.read()) #文件内容

注意:

1.没有

标签(有了也不错)

2.append()方法的第二个参数是文件对象,在html中已经通过loadFile方法的参数传过来

3.后端通过web.input获取文件的字段名,同前端append()方法的第一个参数

4.因为通过web.input获取的值都是字符串,如果除文件以外的键值对传过来是null,会自动转化为字符串'null'。这点处理的时候需要注意

以上所述是小编给大家介绍的jQuery Ajax使用FormData上传文件和其他数据后端web.py获取,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值