jQuery Ajax使用FormData上傳文件和其他數(shù)據(jù)后端web.py獲取
XMLHttpRequest Level 2 添加了一個新的接口——FormData。與普通的 Ajax 相比,使用 FormData 的最大優(yōu)點就是我們可以異步上傳二進制文件。
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()方法的第二個參數(shù)是文件對象,在html中已經通過loadFile方法的參數(shù)傳過來
3.后端通過web.input獲取文件的字段名,同前端append()方法的第一個參數(shù)
4.因為通過web.input獲取的值都是字符串,如果除文件以外的鍵值對傳過來是null,會自動轉化為字符串'null'。這點處理的時候需要注意
以上所述是小編給大家介紹的jQuery Ajax使用FormData上傳文件和其他數(shù)據(jù)后端web.py獲取,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!
相關文章
jquery實現(xiàn)漂浮在網頁右側的qq在線客服插件示例
很實用的一款QQ在線客服代碼,點擊QQ圖標,可直接與客服對話,詳細如下,感興趣的朋友可以參考下哈,希望對你有所幫助2013-05-05
使用jquery+iframe做一個ajax上傳效果(實例)
下面小編就為大家?guī)硪黄褂胘query+iframe做一個ajax上傳效果(實例)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-08-08
jQuery實現(xiàn)鼠標移到某個對象時彈出顯示層功能
這篇文章主要介紹了jQuery實現(xiàn)鼠標移到某個對象時彈出顯示層功能,涉及jQuery基于事件響應動態(tài)操作頁面元素屬性相關實現(xiàn)技巧,需要的朋友可以參考下2018-08-08
checkbox:click事件觸發(fā)span元素內容改變的方法
下面小編就為大家?guī)硪黄猚heckbox:click事件觸發(fā)span元素內容改變的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-09-09

