jQuery Ajax使用FormData上傳文件和其他數(shù)據(jù)后端web.py獲取
XMLHttpRequest Level 2 添加了一個(gè)新的接口——FormData。與普通的 Ajax 相比,使用 FormData 的最大優(yōu)點(diǎn)就是我們可以異步上傳二進(jìn)制文件。
jQuery 2.0+的版本支持FormData
方法一:使用<form>表單初始化FormData對(duì)象方式上傳文件
•前端(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>
•后臺(tái)(web.py):
class Add: def POST(self): i = web.input(myfile={}) print(i['myfile'].filename) #文件名 print(i['myfile'].value) #文件內(nèi)容 print(i['myfile'].file.read()) #文件內(nèi)容
注意:
1.<form>的enctype屬性需要設(shè)置為“multipart/form-data”
2.$.ajax中processData、contentType和cache需要設(shè)置為false
3.后端通過(guò)web.input獲取文件的字段名,同前端指定的input標(biāo)簽的name屬性
方法二√:不用<form>,使用FormData對(duì)象添加字段方式上傳文件
有時(shí),我們并不想用
標(biāo)簽,而且通過(guò)ajax傳給后端的并不只有文件,可能還有其他的鍵值對(duì),這時(shí)就可以用這個(gè)方法
•前端(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 () {} }); }
•后臺(tái)(web.py):
class Add: def POST(self): i = web.input(myfile={}, otherkey='') print(i['myfile'].filename) #文件名 print(i['myfile'].value) #文件內(nèi)容 print(i['myfile'].file.read()) #文件內(nèi)容
注意:
1.沒(méi)有<form>標(biāo)簽(有了也不錯(cuò))
2.append()方法的第二個(gè)參數(shù)是文件對(duì)象,在html中已經(jīng)通過(guò)loadFile方法的參數(shù)傳過(guò)來(lái)
3.后端通過(guò)web.input獲取文件的字段名,同前端append()方法的第一個(gè)參數(shù)
4.因?yàn)橥ㄟ^(guò)web.input獲取的值都是字符串,如果除文件以外的鍵值對(duì)傳過(guò)來(lái)是null,會(huì)自動(dòng)轉(zhuǎn)化為字符串'null'。這點(diǎn)處理的時(shí)候需要注意
以上所述是小編給大家介紹的jQuery Ajax使用FormData上傳文件和其他數(shù)據(jù)后端web.py獲取,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的!
相關(guān)文章
jquery實(shí)現(xiàn)漂浮在網(wǎng)頁(yè)右側(cè)的qq在線客服插件示例
很實(shí)用的一款QQ在線客服代碼,點(diǎn)擊QQ圖標(biāo),可直接與客服對(duì)話,詳細(xì)如下,感興趣的朋友可以參考下哈,希望對(duì)你有所幫助2013-05-05jQuery中innerHeight()方法用法實(shí)例
這篇文章主要介紹了jQuery中innerHeight()方法用法,實(shí)例分析了innerHeight()方法的功能、定義及獲取第一個(gè)匹配元素內(nèi)部區(qū)域高度的使用技巧,需要的朋友可以參考下2015-01-01jQuery實(shí)現(xiàn)簡(jiǎn)單日歷效果
這篇文章主要為大家詳細(xì)介紹了jQuery實(shí)現(xiàn)簡(jiǎn)單日歷效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-07-07使用jquery+iframe做一個(gè)ajax上傳效果(實(shí)例)
下面小編就為大家?guī)?lái)一篇使用jquery+iframe做一個(gè)ajax上傳效果(實(shí)例)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-08-08jQuery文本框得到與失去焦點(diǎn)動(dòng)態(tài)改變樣式效果
這篇文章主要介紹了jQuery文本框得到與失去焦點(diǎn)動(dòng)態(tài)改變樣式效果,涉及jQuery針對(duì)頁(yè)面表單元素樣式的動(dòng)態(tài)操作技巧,需要的朋友可以參考下2016-09-09jQuery實(shí)現(xiàn)鼠標(biāo)移到某個(gè)對(duì)象時(shí)彈出顯示層功能
這篇文章主要介紹了jQuery實(shí)現(xiàn)鼠標(biāo)移到某個(gè)對(duì)象時(shí)彈出顯示層功能,涉及jQuery基于事件響應(yīng)動(dòng)態(tài)操作頁(yè)面元素屬性相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2018-08-08checkbox:click事件觸發(fā)span元素內(nèi)容改變的方法
下面小編就為大家?guī)?lái)一篇checkbox:click事件觸發(fā)span元素內(nèi)容改變的方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09