婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > FormData+Ajax實現上傳進度監控

FormData+Ajax實現上傳進度監控

熱門標簽:電銷機器人 長春 河間市地圖標注app 怎樣在地圖標注文字 東平縣地圖標注app 大眾點評400電話怎么申請 上海企業外呼系統價錢 地圖標注推銷坑人 中國地圖標注不明確情況介紹表 立陶宛地圖標注

什么是FormData?

FormData對象可以組裝一組用 XMLHttpRequest發送請求的鍵/值對。它可以更靈活方便的發送表單數據,因為可以獨立于表單使用。如果你把表單的編碼類型設置為multipart/form-data ,則通過FormData傳輸的數據格式和表單通過submit() 方法傳輸的數據格式相同;

如何創建一個FormData對象

你可以自己創建一個FormData對象,然后通過調用它的append()方法添加字段,就像這樣:

//實例化一個formData對象
var formData = new FormData();
formData.append("username", "Groucho");
formData.append("userid", 123456); // 數字 123456 會被立即轉換成字符串 "123456"
// HTML上的 文件類型input[type=file]的文件框,由用戶選擇
formData.append("userfile", fileInputElement.files[0]);
// JavaScript file-like 對象
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” 都包含一個文件. 字段 “userid” 是數字類型,它將被FormData.append()方法轉換成字符串類型(FormData 對象的字段類型可以是 Blob, File, 或者 string: 如果它的字段類型不是Blob也不是File,則會被轉換成字符串類型。

使用jQuery的Ajax方法發送FormData數據

//記錄當前時間
var time=new Date().getTime();
//記錄當前進度
var percentage =null;
//記錄當前上傳速度
var velocity=null;
//記錄已上傳文件字節大小
var loaded=0;
$.ajax({
 url: 'Url',
 type: "POST",
 data: formData,
 contentType: false, // 必須 不設置內容類型
 processData: false, // 必須 不處理數據
 xhr: function xhr() {
  //獲取原生的xhr對象
  var xhr = $.ajaxSettings.xhr();
  if (xhr.upload) {
   //添加 progress 事件監聽
   xhr.upload.addEventListener('progress', function (e) {
    var nowDate = new Date().getTime();
    //每一秒刷新一次狀態
    if (nowDate - time >= 1000) {
     //已上傳文件字節數/總字節數
     percentage = parseInt(e.loaded / e.total * 100);
     //當前已傳大小(字節數)-一秒前已傳文件大小(字節數)
     velocity = (e.loaded - loaded) / 1024;
     if (percentage >= 99) {
      $(".hintText").html('服務端正在解析,請稍后');
     } else {
      //修改上次記錄時間及數據大小
      time = nowDate;
      loaded = e.loaded;
     }
    } else {
     return;
    }
   }, false);
  }
  return xhr;
 },
 success: function success(response) {
  //成功回調   
 },
 error: function error(error) {
  //失敗回調    
 }
});

總結

以上所述是小編給大家介紹的FormData+Ajax實現上傳進度監控,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

您可能感興趣的文章:
  • JS中使用FormData上傳文件、圖片的方法
  • jQuery用FormData實現文件上傳的方法
  • jQuery Ajax使用FormData對象上傳文件的方法
  • 談談基于iframe、FormData、FileReader三種無刷新上傳文件的方法
  • JS FormData上傳文件的設置方法
  • jQuery+formdata實現上傳進度特效遇到的問題
  • 通過Ajax使用FormData對象無刷新上傳文件方法
  • vuejs使用FormData實現ajax上傳圖片文件
  • jQuery Ajax使用FormData上傳文件和其他數據后端web.py獲取
  • 使用FormData實現上傳多個文件

標簽:內江 營口 益陽 玉樹 本溪 四川 銅川 遼寧

巨人網絡通訊聲明:本文標題《FormData+Ajax實現上傳進度監控》,本文關鍵詞  FormData+Ajax,實現,上傳,進度,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《FormData+Ajax實現上傳進度監控》相關的同類信息!
  • 本頁收集關于FormData+Ajax實現上傳進度監控的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 松溪县| 镇雄县| 康乐县| 鹰潭市| 毕节市| 大兴区| 邻水| 娄烦县| 九江县| 财经| 枞阳县| 曲靖市| 昭通市| 资阳市| 右玉县| 普洱| 林西县| 康乐县| 乐陵市| 射阳县| 乌兰浩特市| 板桥市| 石屏县| 金华市| 浦北县| 陵水| 武胜县| 油尖旺区| 九寨沟县| 三门县| 乐安县| 广水市| 垣曲县| 准格尔旗| 十堰市| 偃师市| 武汉市| 同江市| 田阳县| 包头市| 奎屯市|