欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > Html5 new XMLHttpRequest()監(jiān)聽附件上傳進(jìn)度

Html5 new XMLHttpRequest()監(jiān)聽附件上傳進(jìn)度

熱門標(biāo)簽:江西ai電銷機(jī)器人如何 高德地圖標(biāo)注廁所 西安金倫外呼系統(tǒng) 地圖標(biāo)注沿海城市房價(jià) 中國地圖標(biāo)注城市的 地圖標(biāo)注員工作內(nèi)容 威海語音外呼系統(tǒng)平臺 通遼地圖標(biāo)注app 智能語音電銷機(jī)器人客戶端

本文主要介紹new XMLHttpRequest()監(jiān)聽附件上傳進(jìn)度,解決優(yōu)化loading長時(shí)間加載,用戶等待問題

一、存在問題

經(jīng)測試發(fā)現(xiàn),new XMLHttpRequest()在附件上傳請求中,WIFI關(guān)閉切4G上傳,上傳進(jìn)度不會持續(xù);4G不關(guān)閉打開WIFI會繼續(xù)上傳,但等待時(shí)間過長,實(shí)際上是4G在上傳,倘若關(guān)閉4G網(wǎng)絡(luò),上傳進(jìn)度終止。

二、相關(guān)代碼

2.1 HTML

<div class="process-wrapper" id="processWrap">
 <div class="process-face"></div>
 <img class="close-icon" id="closeBtn" src="../../images/close.png" alt="">
 <div class="process">
  <div class="process-inner" id="processInner" style="width:50%"></div>
  <div class="process-value">
   <span>提交中...</span> 
   <span id="process">0%</span>
  </div>
 </div>
</div>

2.2 CSS樣式

/* 附件上傳進(jìn)度條 */
.process-wrapper{
 -moz-user-select:none;
 position: fixed;
 left: 0;
 top: 0;
 bottom: 0;
 right: 0;
 z-index: 10000;
 display: none;
}
.process-face{
 width: 100%;
 height: 100%;
 background-color: #000;
 opacity: 0.7;
 position: fixed;
}
.close-icon{
 width: 26px;
 height: 26px;
 position: fixed;
 left: 50%;
 top: calc( 50% + 40px );
 transform: translate(-50%,-50%);
}
.process{
 width: 90%;
 height: 30px;
 background-color: #fff;
 border-radius: 30px;
 overflow: hidden;
 position: absolute;
 left: 50%;
 top: 50%;
 transform: translate(-50%,-50%);
 text-align: center;
 font-size: 14px;
 line-height: 30px;
 color: #999;
}
.process-inner{
 width: 100%;
 height: 30px;
 position: absolute;
 left: 0;
 top: 0;
 background-color: #0079C1;
 transition: 0.1s;
 z-index: -1;
}

2.3 JS

(function(app, doc) {
 
 var $processWrap = document.getElementById("processWrap"),
 $closeBtn = document.getElementById("closeBtn"),
 xhr = new XMLHttpRequest();
 doc.addEventListener('netchange', onNetChange, false);
 function onNetChange() {
  if ($processWrap.style.display != "none") {
   $processWrap.style.display = "none";
   xhr.abort();
   mui.toast('網(wǎng)絡(luò)中斷請重試');
  }
 }
 doSend: function() {
   app.ajaxFile({  //封裝好的ajax請求 
   url: "",
   data: FormData,
   xhr: xhr,
   success: function(r) {
    if (r == '1') {
     mui.toast("保存成功");
     // 上傳成功邏輯處理
    } else {
     $processWrap.style.display = "none";
     mui.toast(app.netError);
    }
   },
   error: function(r) {
    $processWrap.style.display = "none";
   },
   progress: function(e) {
    if (e.lengthComputable) {
     var progressBar = parseInt((e.loaded / e.total) * 100);
     if (progressBar < 100) {
      $progress.innerHTML = progressBar + "%";
      $processInner.style.width = progressBar + "%";
     }
    }
   },
   timeout:function(){
    $processWrap.style.display = "none";
   }

  });
 })
 mui.plusReady(function() {
  $closeBtn.addEventListener("tap",function(){
   setTimeout(function(){
    $processWrap.style.display = "none";
    xhr.abort();
   }, 400);
  })
 });
})(app, document);

三、app.js封裝ajax請求

var $ajaxCount = 0;

window.app = {
 //ajaxFile超時(shí)時(shí)間
 fileTimeout: 180000,
 ajaxFile: function(option) {
 $ajaxCount++; 
 var _ajaxCount = $ajaxCount;
 if (!option.error) {
  option.error = ajaxError; // 請求失敗提示
 }
 if (option.validateUserInfo == undefined) option.validateUserInfo = true;
 var xhr = option.xhr || new XMLHttpRequest();
 xhr.timeout = app.fileTimeout;
 xhr.open('POST', app.getItem(app.localKey.url) + option.url, true);
 xhr.onreadystatechange = function() {
  if (xhr.readyState == 4 && xhr.status == 200) {
   var r = xhr.responseText;
   if (r) {
    r = JSON.parse(r);
   }
   if (_ajaxCount == $ajaxCount) {
    option.success && option.success(r);
   }
  }
 }
 xhr.upload.onprogress = function (e) {
  option.progress(e);
 }
 xhr.onerror = function(e) {
  option.error(e); // 添加 上傳失敗后的回調(diào)函數(shù)
 }
 xhr.ontimeout = function(e){
  option.timeout(e);
  app.closeWaiting();
  $.toast("請求超時(shí),請重試");
  xhr.abort();
  }
 xhr.send(option.data);
},
}

拓展:后端NodeJS實(shí)現(xiàn)代碼

const express = require("express");
const multer = require("multer");
const expressStatic = require("express-static");
const fs = require("fs");

let server = express();
let upload = multer({ dest: __dirname+'/uploads/' })
// 處理提交文件的post請求
server.post('/upload_file', upload.single('file'), function (req, res, next) {
  console.log("file信息", req.file);
  fs.rename(req.file.path, req.file.path+"."+req.file.mimetype.split("/").pop(), ()=>{
    res.send({status: 1000})
  })
})

// 處理靜態(tài)目錄
server.use(expressStatic(__dirname+"/www"))
// 監(jiān)聽服務(wù)
server.listen(8080, function(){
  console.log("請使用瀏覽器訪問 http://localhost:8080/")
});

到此這篇關(guān)于Html5 new XMLHttpRequest()監(jiān)聽附件上傳進(jìn)度的文章就介紹到這了,更多相關(guān)Html5 監(jiān)聽附件上傳內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持腳本之家!

標(biāo)簽:阜陽 崇左 眉山 青海 晉中 河池 北海 營口

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Html5 new XMLHttpRequest()監(jiān)聽附件上傳進(jìn)度》,本文關(guān)鍵詞  Html5,new,XMLHttpRequest,監(jiān)聽,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Html5 new XMLHttpRequest()監(jiān)聽附件上傳進(jìn)度》相關(guān)的同類信息!
  • 本頁收集關(guān)于Html5 new XMLHttpRequest()監(jiān)聽附件上傳進(jìn)度的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    亚洲人成人一区二区在线观看 | 粗大的内捧猛烈进出视频| www色com| 欧美大度的电影原声| 久久尤物电影视频在线观看| 日日夜夜精品视频天天综合网| 日本r级电影在线观看| avove在线播放| 国产精品免费视频观看| 偷偷要91色婷婷| 国产一级免费片| 欧美另类久久久品| 亚洲成人你懂的| 成人午夜av电影| 青青青在线免费观看| 国产精品免费人成网站| 成人av网站在线观看免费| 色综合久久99| 亚洲精品成人a在线观看| 国产露脸91国语对白| 艳妇乳肉豪妇荡乳xxx| 777午夜精品视频在线播放| 亚洲欧洲一区二区三区| 精品在线播放午夜| 天天干天天操天天拍| 欧美国产欧美亚州国产日韩mv天天看完整 | 亚洲精品在线一区二区| 亚洲亚洲精品在线观看| 成年女人免费视频| 日韩午夜电影av| 亚洲一区在线观看视频| 色综合久久五月| 欧美r级在线观看| 亚洲高清视频在线| 99精品国产99久久久久久白柏| 99久久久无码国产精品衣服| 国产视频一区在线观看| 成人激情免费视频| 情侣偷拍对白清晰饥渴难耐| 久久综合视频网| 日韩av一二三| 日本午夜精品视频| 久久夜色精品一区| 麻豆91在线观看| 国产又粗又猛又爽又黄的视频小说| 精品奇米国产一区二区三区| 亚洲成av人片在线观看| 国产ts在线播放| 国产精品九色蝌蚪自拍| 国产成人免费9x9x人网站视频| 色狠狠av一区二区三区| 丝袜美腿成人在线| 黑丝av在线播放| 国产拍欧美日韩视频二区| a级高清视频欧美日韩| 18岁成人毛片| 偷窥国产亚洲免费视频| 亚洲精品ww久久久久久p站| 欧美一级xxx| 狠狠狠色丁香婷婷综合激情| 色婷婷国产精品综合在线观看| 午夜精品成人在线| 亚洲av人人澡人人爽人人夜夜| 亚洲精品一区二区三区精华液| 麻豆精品视频在线观看| 精品国产精品国产精品| 午夜精品福利一区二区蜜股av| 午夜不卡久久精品无码免费| 久久久久88色偷偷免费| 日本黄色三级网站| 久久色中文字幕| 在线观看欧美一区二区| 精品免费国产一区二区三区四区| 白白色 亚洲乱淫| 欧美精品一区视频| 黑人无套内谢中国美女| 国产精品丝袜在线| 丰满大乳奶做爰ⅹxx视频| 中文字幕一区二区三区蜜月| 六十路息与子猛烈交尾| 亚洲男同性视频| 日本人亚洲人jjzzjjz| 亚洲午夜国产一区99re久久| 熟妇高潮精品一区二区三区| 国产精品福利电影一区二区三区四区| 99国产一区二区三精品乱码| 欧美伦理影视网| 成人ar影院免费观看视频| 精品免费视频一区二区| 国产精品99久久久久久久女警 | 欧美一区免费观看| 亚洲美女免费在线| 一级黄色片毛片| www欧美成人18+| 亚洲欧美日韩色| 亚洲欧美二区三区| 最新av电影网站| 久88久久88久久久| 91精品国产高清一区二区三区蜜臀| 不卡的av电影| 欧美激情一区二区三区全黄| 亚洲国产欧美视频| 亚洲成人一区二区| 日本大香伊一区二区三区| 国产精品99久| 欧美日韩成人一区二区| jlzzjlzz国产精品久久| 欧美国产丝袜视频| 麻豆精品国产传媒av| 国产日韩av一区| 69精品无码成人久久久久久| 日韩1区2区日韩1区2区| 欧美猛男男办公室激情| 无码人妻少妇色欲av一区二区| 亚洲欧洲日本在线| 97超碰在线免费观看| 日韩成人精品在线观看| 6080yy午夜一二三区久久| 性xxxxxxxxx| 国产蜜臀av在线一区二区三区| 精品欧美一区二区久久久| 亚洲乱码国产乱码精品精的特点 | 91欧美一区二区| 自拍偷拍国产精品| 国产又爽又黄网站| 麻豆成人91精品二区三区| 日韩精品一区二区在线| 91农村精品一区二区在线| 亚洲视频你懂的| 色婷婷久久久亚洲一区二区三区| 成人污污视频在线观看| 亚洲视频 欧洲视频| 91视频免费在观看| 国模大尺度一区二区三区| 久久欧美中文字幕| 欧美日韩人妻精品一区在线| 日韩美女视频一区| 日本国产一区二区| 无套白嫩进入乌克兰美女| 一区二区国产盗摄色噜噜| 美女福利视频网| 国产成人日日夜夜| 中文字幕在线一区二区三区| 色综合天天综合狠狠| 加勒比av一区二区| 91精品综合久久久久久| 91在线码无精品| 亚洲一区二区黄色| 一本久久a久久免费精品不卡| 97se亚洲国产综合自在线观| 一区二区三区四区不卡视频| 欧美男同性恋视频网站| 91丝袜高跟美女视频| 国产精品国模大尺度视频| 国产不卡在线观看视频| 成人毛片在线观看| 亚洲一区影音先锋| 91福利资源站| 白嫩情侣偷拍呻吟刺激| 捆绑调教美女网站视频一区| 国产偷v国产偷v亚洲高清| 日韩黄色免费观看| 顶级嫩模精品视频在线看| 国产亚洲人成网站| 美女福利视频在线观看| 国产人妖在线观看| 美女视频网站黄色亚洲| 日韩三级在线观看| 少妇视频一区二区| 亚洲国产综合av| 一区二区在线看| 精品日本一线二线三线不卡| 国产高清自拍视频| 国产成人亚洲综合色影视 | 青青草华人在线视频| 成人动漫在线一区| 舔着乳尖日韩一区| 国产欧美日韩在线看| 亚洲欧洲制服丝袜| 日本韩国欧美在线| 成人网站免费观看| 图片区日韩欧美亚洲| 欧美一级一级性生活免费录像| 欧美巨胸大乳hitomi| 18深夜在线观看免费视频| 亚洲小说春色综合另类电影| 欧美裸体一区二区三区| 强迫凌虐淫辱の牝奴在线观看| 国产精品一区在线| 国产精品黄色在线观看| 在线免费精品视频| 国产精品成人免费一区久久羞羞| 久久疯狂做爰流白浆xx| 国产视频亚洲色图| 欧美性videosxxxxx| 久草视频福利在线| 国产99久久久国产精品潘金 | 日本一区二区电影| 911精品产国品一二三产区| 亚洲精品中文字幕在线播放|