您好,欢迎访问一九零五行业门户网

jQuery Ajax使用FormData上传文件和其他数据实例详解

这篇文章主要介绍了jquery ajax使用formdata上传文件和其他数据后端web.py获取 ,需要的朋友可以参考下,希望能帮助到大家。
xmlhttprequest level 2 添加了一个新的接口——formdata。与普通的 ajax 相比,使用 formdata 的最大优点就是我们可以异步上传二进制文件。
jquery 2.0+的版本支持formdata
方法一:使用<form>表单初始化formdata对象方式上传文件
•前端(jquery):
<form enctype="multipart/form-data">   <input type="file" name="myfile" onchange="loadfile(this.files[0])"> </form> <script>   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 () {}     });   } </script>
•后台(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.<form>的enctype属性需要设置为“multipart/form-data”
2.$.ajax中processdata、contenttype和cache需要设置为false
3.后端通过web.input获取文件的字段名,同前端指定的input标签的name属性
方法二√:不用<form>,使用formdata对象添加字段方式上传文件
有时,我们并不想用
标签,而且通过ajax传给后端的并不只有文件,可能还有其他的键值对,这时就可以用这个方法
•前端(jquery):
<input type="file" onchange="loadfile(this.files[0])" /> 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.没有<form>标签(有了也不错)
2.append()方法的第二个参数是文件对象,在html中已经通过loadfile方法的参数传过来
3.后端通过web.input获取文件的字段名,同前端append()方法的第一个参数
4.因为通过web.input获取的值都是字符串,如果除文件以外的键值对传过来是null,会自动转化为字符串'null'。这点处理的时候需要注意
相关推荐:
html里formdata对象的详细介绍
使用formdata提交表单及上传图片的方法
javascript中formdata 在对象运用
以上就是jquery ajax使用formdata上传文件和其他数据实例详解的详细内容。
其它类似信息

推荐信息