温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

jQuery Ajax如何使用FormData上传文件和其他数据后端web.py

发布时间:2021-05-25 09:46:21 来源:亿速云 阅读:311 作者:小新 栏目:web开发

这篇文章将为大家详细讲解有关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'。这点处理的时候需要注意

jquery是什么

jquery是一个简洁而快速的JavaScript库,它具有独特的链式语法和短小清晰的多功能接口、高效灵活的css选择器,并且可对CSS选择器进行扩展、拥有便捷的插件扩展机制和丰富的插件,是继Prototype之后又一个优秀的JavaScript代码库,能够用于简化事件处理、HTML文档遍历、Ajax交互和动画,以便快速开发网站。

关于“jQuery Ajax如何使用FormData上传文件和其他数据后端web.py”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI