欧美阿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>
    中文字幕第3页| 精品久久人人做人人爽| 国产精品免费观看视频| 狠狠网亚洲精品| 国产男女猛烈无遮挡a片漫画 | 午夜精品爽啪视频| 91麻豆国产自产在线观看| 亚洲av鲁丝一区二区三区| 中文字幕精品—区二区四季| 国内精品伊人久久久久av影院| 日本少妇高潮喷水xxxxxxx| 日韩一级片网址| 日本aⅴ免费视频一区二区三区| 亚洲天堂美女视频| 欧美一区二区三级| 男女性色大片免费观看一区二区| 久久人人妻人人人人妻性色av| 欧美一区二区三区日韩视频| 婷婷一区二区三区| 亚洲一区二区三区无码久久| 日韩欧美不卡在线观看视频| 男人的天堂久久精品| 一本加勒比北条麻妃| 久久综合色天天久久综合图片| 精品一区二区成人精品| 无码人中文字幕| 国产精品久久久久久妇女6080| 成人开心网精品视频| 一本大道av一区二区在线播放| 综合在线观看色| 绯色av蜜臀vs少妇| 91精品啪在线观看国产60岁| 秋霞电影一区二区| 蜜桃av免费观看| 亚洲欧洲日本在线| 免费黄视频在线观看| 91精品国产色综合久久不卡蜜臀| 美女在线视频一区| 小向美奈子av| 一二三四区精品视频| bl动漫在线观看| 久久综合av免费| 成人激情视频网站| 欧美日韩精品一区二区在线播放| 日韩国产在线观看一区| 91社区视频在线观看| 亚洲欧洲精品一区二区精品久久久 | 在线观看欧美一区二区| 欧美一级二级三级蜜桃| 国产一区二区不卡在线 | 亚洲人成精品久久久久久| 欧美人与性动交α欧美精品| 欧美一区二区免费| 日韩你懂的在线播放| 国产尤物一区二区在线| 日本高清不卡在线观看| 青青草97国产精品免费观看 | 欧美视频一区二区在线观看| 日韩在线a电影| 在线观看天堂av| 亚洲综合在线五月| 色欲AV无码精品一区二区久久| 中文字幕一区二区不卡| 中文字幕精品久久久| 亚洲国产成人在线| 精品人妻伦一二三区久| 国产三区在线成人av| 中文字幕在线播放一区二区| 欧美精品一区二区三区在线| 99麻豆久久久国产精品免费优播| 日韩欧美一二区| 99re8在线精品视频免费播放| 日韩视频在线一区二区| www.久久精品| 精品国产百合女同互慰| 91免费国产在线观看| 久久久青草青青国产亚洲免观| 深夜福利网站在线观看| 国产亚洲短视频| www.男人天堂| 中文字幕日韩精品一区| b站大片免费直播| 亚洲一区电影777| 亚洲欧美精品aaaaaa片| 日韩成人午夜电影| 91精品91久久久中77777| 精品制服美女久久| 欧美精选一区二区| 不卡一区二区三区四区| 久久综合五月天婷婷伊人| 老司机午夜免费福利| 亚洲欧洲精品一区二区三区| 调教驯服丰满美艳麻麻在线视频| 亚洲午夜久久久久| 色综合久久久久综合99| 国产一区日韩二区欧美三区| 日韩一区二区在线观看| 91av免费观看| 成人欧美一区二区三区在线播放| 一区二区三区伦理片| 午夜精品福利一区二区蜜股av| 天天看片中文字幕| 国产一区美女在线| 精品欧美一区二区三区精品久久| 国产女主播在线播放| 亚洲欧美激情一区二区| 亚洲怡红院在线观看| 国内精品伊人久久久久av影院 | 永久免费看片在线观看| 国产精品乱人伦中文| 一级黄色片网址| 麻豆精品一区二区三区| 91精品福利在线一区二区三区 | 99视频精品免费视频| 欧美激情综合五月色丁香小说| 丰满少妇一区二区| 青娱乐精品视频| 欧美一区二区三区成人| 国产草草浮力影院| 五月激情综合色| 7878成人国产在线观看| 影音先锋资源av| 亚洲高清免费视频| 欧美三级中文字幕在线观看| 91免费观看视频在线| 亚洲美女少妇撒尿| 在线视频观看一区| 两女双腿交缠激烈磨豆腐| 亚洲人精品一区| 91久久精品网| 人妻巨大乳一二三区| 一区二区三区四区av| 欧美在线观看视频在线| 91蜜桃免费观看视频| 一区二区在线观看免费| 欧美系列一区二区| 中文在线字幕观看| 五月天丁香久久| 欧美成人激情免费网| 午夜在线观看一区| 国产麻豆9l精品三级站| 国产精品久久久久久久久晋中| 午夜激情福利网| 91在线丨porny丨国产| 亚洲激情第一区| 在线播放91灌醉迷j高跟美女 | 国产综合色视频| 欧美国产一区二区在线观看 | 青青操在线视频观看| 丁香桃色午夜亚洲一区二区三区 | jizz中文字幕| 国产成人日日夜夜| 亚洲人成网站影音先锋播放| 欧美性淫爽ww久久久久无| 国产精品果冻传媒| 麻豆国产精品视频| 国产欧美一区二区精品婷婷| 老熟妻内射精品一区| 亚洲三级在线视频| 日韩电影在线一区| 国产蜜臀97一区二区三区| 一本久久a久久免费精品不卡| 日本黄色大片在线观看| 蜜桃精品视频在线观看| 欧美激情资源网| 欧洲精品一区二区| 欧美图片一区二区| 国产91精品免费| 亚洲国产日韩综合久久精品| 日韩欧美国产精品| 五月综合色婷婷| 乱码一区二区三区| 经典三级一区二区| 亚洲美女视频在线| 日韩精品自拍偷拍| 亚洲av无码一区二区三区在线| 久久无码专区国产精品s| 久久狠狠亚洲综合| 亚洲色图另类专区| 精品日韩在线观看| 色综合婷婷久久| 日本黄色特级片| 成年人国产精品| 六月婷婷色综合| 一区二区在线观看免费视频播放| 日韩美女主播在线视频一区二区三区| 四虎影视一区二区| 国产69视频在线观看| 国产成人免费9x9x人网站视频| 亚洲大片免费看| 中文av一区特黄| 日韩一区二区免费在线观看| 麻豆91在线观看| 亚洲一区二区视频在线观看| 久久综合色天天久久综合图片| 欧美在线观看视频在线| 99久久99久久精品免费| www.17c.com喷水少妇| 成人三级伦理片| 美女视频黄a大片欧美|