FormData+Ajax實(shí)現(xiàn)上傳進(jìn)度監(jiān)控
什么是FormData?
FormData對(duì)象可以組裝一組用 XMLHttpRequest發(fā)送請(qǐng)求的鍵/值對(duì)。它可以更靈活方便的發(fā)送表單數(shù)據(jù),因?yàn)榭梢元?dú)立于表單使用。如果你把表單的編碼類型設(shè)置為multipart/form-data ,則通過(guò)FormData傳輸?shù)臄?shù)據(jù)格式和表單通過(guò)submit() 方法傳輸?shù)臄?shù)據(jù)格式相同;
如何創(chuàng)建一個(gè)FormData對(duì)象
你可以自己創(chuàng)建一個(gè)FormData對(duì)象,然后通過(guò)調(diào)用它的append()方法添加字段,就像這樣:
//實(shí)例化一個(gè)formData對(duì)象 var formData = new FormData(); formData.append("username", "Groucho"); formData.append("userid", 123456); // 數(shù)字 123456 會(huì)被立即轉(zhuǎn)換成字符串 "123456" // HTML上的 文件類型input[type=file]的文件框,由用戶選擇 formData.append("userfile", fileInputElement.files[0]); // JavaScript file-like 對(duì)象 var content = '<a id="a"><b id="b">hey!</b></a>'; // 新文件的正文... var blob = new Blob([content], { type: "text/xml"}); formData.append("webmasterfile", blob);
注意:字段 “userfile” 和 “webmasterfile” 都包含一個(gè)文件. 字段 “userid” 是數(shù)字類型,它將被FormData.append()方法轉(zhuǎn)換成字符串類型(FormData 對(duì)象的字段類型可以是 Blob, File, 或者 string: 如果它的字段類型不是Blob也不是File,則會(huì)被轉(zhuǎn)換成字符串類型。
使用jQuery的Ajax方法發(fā)送FormData數(shù)據(jù)
//記錄當(dāng)前時(shí)間 var time=new Date().getTime(); //記錄當(dāng)前進(jìn)度 var percentage =null; //記錄當(dāng)前上傳速度 var velocity=null; //記錄已上傳文件字節(jié)大小 var loaded=0; $.ajax({ url: 'Url', type: "POST", data: formData, contentType: false, // 必須 不設(shè)置內(nèi)容類型 processData: false, // 必須 不處理數(shù)據(jù) xhr: function xhr() { //獲取原生的xhr對(duì)象 var xhr = $.ajaxSettings.xhr(); if (xhr.upload) { //添加 progress 事件監(jiān)聽(tīng) xhr.upload.addEventListener('progress', function (e) { var nowDate = new Date().getTime(); //每一秒刷新一次狀態(tài) if (nowDate - time >= 1000) { //已上傳文件字節(jié)數(shù)/總字節(jié)數(shù) percentage = parseInt(e.loaded / e.total * 100); //當(dāng)前已傳大小(字節(jié)數(shù))-一秒前已傳文件大小(字節(jié)數(shù)) velocity = (e.loaded - loaded) / 1024; if (percentage >= 99) { $(".hintText").html('服務(wù)端正在解析,請(qǐng)稍后'); } else { //修改上次記錄時(shí)間及數(shù)據(jù)大小 time = nowDate; loaded = e.loaded; } } else { return; } }, false); } return xhr; }, success: function success(response) { //成功回調(diào) }, error: function error(error) { //失敗回調(diào) } });
總結(jié)
以上所述是小編給大家介紹的FormData+Ajax實(shí)現(xiàn)上傳進(jìn)度監(jiān)控,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- JS中使用FormData上傳文件、圖片的方法
- jQuery用FormData實(shí)現(xiàn)文件上傳的方法
- jQuery Ajax使用FormData對(duì)象上傳文件的方法
- 談?wù)劵趇frame、FormData、FileReader三種無(wú)刷新上傳文件的方法
- JS FormData上傳文件的設(shè)置方法
- jQuery+formdata實(shí)現(xiàn)上傳進(jìn)度特效遇到的問(wèn)題
- 通過(guò)Ajax使用FormData對(duì)象無(wú)刷新上傳文件方法
- vuejs使用FormData實(shí)現(xiàn)ajax上傳圖片文件
- jQuery Ajax使用FormData上傳文件和其他數(shù)據(jù)后端web.py獲取
- 使用FormData實(shí)現(xiàn)上傳多個(gè)文件
相關(guān)文章
結(jié)合AJAX進(jìn)行PHP開(kāi)發(fā)之入門
結(jié)合AJAX進(jìn)行PHP開(kāi)發(fā)之入門...2006-12-12kkpager 實(shí)現(xiàn)ajax分頁(yè)查詢功能
kkpager 實(shí)現(xiàn)ajax分頁(yè)查詢功能,前臺(tái)分頁(yè)數(shù)據(jù),適合數(shù)據(jù)少量的時(shí)候,因?yàn)榉猪?yè)的數(shù)據(jù)是從后臺(tái)獲取的,大數(shù)據(jù)的話不建議使用 ,具體前后臺(tái)代碼大家參考下本文吧2017-08-08Ajax學(xué)習(xí)筆記---3種Ajax的實(shí)現(xiàn)方法【推薦】
下面小編就為大家?guī)?lái)一篇Ajax學(xué)習(xí)筆記---3種Ajax的實(shí)現(xiàn)方法【推薦】。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考2016-05-05ajax動(dòng)態(tài)獲取數(shù)據(jù)庫(kù)中的數(shù)據(jù)方法
今天小編就為大家分享一篇ajax動(dòng)態(tài)獲取數(shù)據(jù)庫(kù)中的數(shù)據(jù)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-08-08Ajax實(shí)現(xiàn)城市二級(jí)聯(lián)動(dòng)(三)
這篇文章主要為大家詳細(xì)介紹了Ajax實(shí)現(xiàn)城市二級(jí)聯(lián)動(dòng)的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02