这篇文章主要介绍了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'。这点处理的时候需要注意 相关推荐: HTML里FormData对象的详细介绍 使用FormData提交表单及上传图片的方法 JavaScript中FormData 在对象运用