日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

利用js實現Ajax并發請求限制請求數量的示例代碼

瀏覽:201日期:2024-04-02 15:05:21

出現問題描述:當不確定異步請求個數時,為防止當一瞬間發生上百個http請求時,導致堆積了無數調用棧進而導致內存溢出問題。

要求:將同一時刻并發請求數量控制在3個以內,同時還要盡可能快速的拿到響應的結果。

同面試問題:

實現一個批量請求函數 multiRequest(urls, maxNum),要求如下:

要求最大并發數 maxNum 每當有一個請求返回,就留下一個空位,可以增加新的請求 所有請求完成后,結果按照 urls 里面的順序依次打出1、基于Promise.all實現Ajax的串行和并行

平時都是基于promise來封裝異步請求的

串行:一個異步請求完成了之后再進行下一個請求

并行:多個異步請求同時進行

示例:串行

var p = function () { return new Promise(function (resolve, reject) { setTimeout(() => { console.log(’1000’) resolve() }, 1000) })}var p1 = function () { return new Promise(function (resolve, reject) { setTimeout(() => { console.log(’2000’) resolve() }, 2000) })}var p2 = function () { return new Promise(function (resolve, reject) { setTimeout(() => { console.log(’3000’) resolve() }, 3000) })}p().then(() => { return p1()}).then(() => { return p2()}).then(() => { console.log(’end’)})

并行:

var promises = function () { return [1000, 2000, 3000].map(current => { return new Promise(function (resolve, reject) { setTimeout(() => { console.log(current) }, current) }) })}Promise.all(promises()).then(() => { console.log(’end’)})Promise.all(promises: []).then(fun: function);

promise.all保證數組中所有promise對象都達到resolve狀態,才執行then回調

Promise.all并發限制

含義: 指每個時刻并發執行的promise數量是固定的,最終執行的結果還是保持與原來的promise.all一致。

思路與實現

采用遞歸調用來實現,設置最大請求數量上限。并在這些請求中的每一個都應該在完成時繼續遞歸發送,通過傳入的索引來確定了urls里面具體是那個URL,保證最后輸出的順序不會亂,而是依次輸出

代碼實現:

function multiRequest(urls = [], maxNum) { // 請求總數量 const len = urls.length; // 根據請求數量創建一個數組來保存請求的結果 const result = new Array(len).fill(false); // 當前完成的數量 let count = 0; return new Promise((resolve, reject) => { // 請求maxNum個 while (count < maxNum) { next(); } function next() { let current = count++; // 處理邊界條件 if (current >= len) { // 請求全部完成就將promise置為成功狀態, 然后將result作為promise值返回 !result.includes(false) && resolve(result); return; } const url = urls[current]; console.log(`開始 ${current}`, new Date().toLocaleString()); fetch(url) .then((res) => { // 保存請求結果 result[current] = res; console.log(`完成 ${current}`, new Date().toLocaleString()); // 請求沒有全部完成, 就遞歸 if (current < len) { next(); } }) .catch((err) => { console.log(`結束 ${current}`, new Date().toLocaleString()); result[current] = err; // 請求沒有全部完成, 就遞歸 if (current < len) { next(); } }); } });}

代碼實現:

// 任務列表->新建任務 uploadFile() { let _this = this; var uploadThreadLimitNums = 3, uploadThreadNums = 0, sendFinishNum = 0, resultFinishNum = 0; var marks = 0; var tasks = []; var upload = function () { while (uploadThreadNums < uploadThreadLimitNums) { if (sendFinishNum >= _this.fileList.length) { if (resultFinishNum >= _this.fileList.length) { creatTask(); // 完成請求 } return; } (function (j) { let item = _this.fileList[j]; let p = new FormData(); p.append('file', item); tasks.push( axios({method: 'post',url: `${window.UL_CONFIG.BASEURL}/api/files/upload`,data: p,onUploadProgress: (progressEvent) => { for (let i in _this.rowData) { _this.rowData[i].name === item.name ? (_this.rowData[i].percent = Math.round( (progressEvent.loaded / progressEvent.total) * 100 )) : ''; }}, }).then((res) => {/* let obj = {}; obj.url = `${window.UL_CONFIG.BASEURL}/api/files/${res.data}`; obj.fileName = item.name; obj.fmt = _this.ruleForm.format; obj.samplingRate = _this.ruleForm.samplingRate; fileUrls.push(obj); */}).catch((e) => { ? (_this.rowData[i].percent = 0) _this.$notify.error({ title: '錯誤', message: '服務連接錯誤 ' + item.name + ' 未上傳成功', });.finally(() => { uploadThreadNums--; resultFinishNum++; upload(); ); })(sendFinishNum); uploadThreadNums++; sendFinishNum++; } }; var creatTask = function () { axios.all(tasks).then((res) => { // 新建上傳任務 /* let fd1, fd2, calcFlag, flagArr, language; fd1 = {}; flagArr = Object.assign([], _this.ruleForm.checkList); if (_this.ruleForm.recognize == '自動識別') { flagArr.push('2'); calcFlag = flagArr.reduce( (accu, curr) => Number(accu) + Number(curr) ); _this.ruleForm.recognize == '自動識別' ? (language = '') : (language = _this.ruleForm.recognize); fd1.processContent = calcFlag; fd1.remark = _this.ruleForm.remark; fd1.name = _this.ruleForm.taskName; fd1.fmt = _this.ruleForm.format; fd1.samplingRate = _this.ruleForm.samplingRate; fd1.language = language; fd1.type = 1; // type: 1 語音, 2 視頻 fd1.files = fileUrls; */ newTask(fd1).then((res) => { /* _this.cmpltBtnState = false; _this.$store.commit('setTaskId', res.data.id); _this.submitFailNumber = res.data.submitFailNumber; */ _this.$parent.dataInit(); }); }); upload(); },

到此這篇關于利用js實現Ajax并發請求限制請求數量的示例代碼的文章就介紹到這了,更多相關js Ajax并發請求限制內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲免费专区| 亚洲尤物在线| 日韩一级网站| 欧美日韩精品一区二区视频| 欧美不卡高清一区二区三区| 日韩欧美网址| 国产一区观看| 玖玖玖国产精品| 日韩高清成人在线| 国产精品www.| 伊人久久在线| 一区二区三区四区日本视频| 在线视频观看日韩| 美女久久网站| 国产欧美丝祙| 日韩伦理福利| 美美哒免费高清在线观看视频一区二区| 美国三级日本三级久久99| 7m精品国产导航在线| 男人的天堂久久精品| 天堂av在线| 蜜桃精品在线| 久久电影tv| 欧美综合社区国产| 国产高清亚洲| 麻豆成人91精品二区三区| 精品一区二区三区在线观看视频| 91午夜精品| 国产精品片aa在线观看| 精品视频一区二区三区在线观看| 九九99久久精品在免费线bt| 日本一区免费网站| 热久久免费视频| 久久免费精品| 日产精品一区二区| 日韩欧美国产精品综合嫩v| 九一国产精品| 亚洲乱码视频| 久久只有精品| 激情欧美日韩一区| 亚洲激精日韩激精欧美精品| 中文在线日韩| 亚洲人成在线影院| 国产精品极品在线观看| sm捆绑调教国产免费网站在线观看 | 久久成人福利| 高清不卡一区| 亚洲国产一区二区三区在线播放| 亚洲欧美日韩视频二区| 欧美一区影院| 国产成人免费| 亚洲精品网址| 日韩欧美2区| 国产欧美日韩影院| 国产videos久久| aa亚洲婷婷| 奇米狠狠一区二区三区| 免费一区二区三区在线视频| 视频二区不卡| 亚洲精品护士| 98精品久久久久久久| 久久久久一区| 在线国产精品一区| 成人午夜毛片| 中文一区一区三区免费在线观 | 亚洲最新av| 欧美精品三级在线| 香蕉成人av| 亚洲尤物av| 91中文字幕精品永久在线| 日韩欧美午夜| 欧美一区久久| 久久久久国产精品一区三寸| 最新国产精品| 欧产日产国产精品视频| 亚洲精品第一| 99久久夜色精品国产亚洲1000部 | 久久在线免费| 日本中文字幕一区二区视频| 欧美三级网址| 午夜日韩av| 日本特黄久久久高潮| 韩国久久久久久| 国产精品久久久久久av公交车| 亚洲午夜一级| 国产经典一区| 99视频在线精品国自产拍免费观看| 色狠狠一区二区三区| 亚洲不卡av不卡一区二区| 国产欧美88| 亚洲欧洲国产精品一区| 99热国内精品| 精品国产一区二区三区性色av| 午夜电影一区| 亚洲一区不卡| 久久久久久免费视频| 欧美黄色精品| 日韩二区三区在线观看| 国产一区欧美| 日韩精品中文字幕第1页| 日本在线不卡视频一二三区| 午夜影院一区| 欧美日本三区| 99精品一区| 久久成人福利| 日韩一区二区三区免费视频| 伊人成人在线视频| 中文字幕亚洲精品乱码| 久久人人99| 日韩精品第一区| 狠狠久久伊人中文字幕| 国产精品高潮呻吟久久久久| 日韩精品一区二区三区中文字幕| 亚洲伊人精品酒店| 一本一道久久a久久精品蜜桃| 精品久久美女| 亚洲精品一二三**| 另类av一区二区| 五月天激情综合网| 日韩综合精品| 国产极品一区| 牛牛精品成人免费视频| 欧美一级一区| 亚洲精品乱码久久久久久蜜桃麻豆| 日韩视频二区| av不卡免费看| 日韩影院精彩在线| 视频精品一区二区| 久久福利精品| 久久午夜视频| 日本а中文在线天堂| 精品国产欧美日韩| 精品一区二区男人吃奶| 国产精品1区| 欧美激情精品| 黄色aa久久| 国产99久久| 日韩在线观看| 欧美日韩视频网站| 久久麻豆精品| 久久aⅴ国产紧身牛仔裤| 日韩视频1区| 精品美女视频| 国产99久久久国产精品成人免费| 欧美日韩中文字幕一区二区三区| 黄色不卡一区| 在线视频亚洲欧美中文| 日韩一区二区三区精品 | 国产亚洲一卡2卡3卡4卡新区| 91免费精品国偷自产在线在线| 欧美久久精品| 美女精品视频在线| av日韩中文| 日韩中文首页| 免费久久99精品国产| 国产日韩一区二区三区在线| 亚洲三级欧美| 狠狠爱www人成狠狠爱综合网| 久久亚洲欧美| 国产欧美日韩一区二区三区四区| 国产欧美日韩在线观看视频| 日韩av自拍| 伊人久久成人| 久久激五月天综合精品| 精品亚洲美女网站| 蜜臀久久久久久久| 久久久久伊人| 亚洲图片久久| 国产伦久视频在线观看| 最新日韩欧美| 国产精品入口久久| 高清av不卡| 亚洲精品亚洲人成在线观看| 精品亚洲免a| 中文久久精品| 69堂精品视频在线播放| 日韩成人亚洲| 亚洲精品福利| 精品国产亚洲一区二区在线观看| 99精品在线| 国产精品久久久久久久久久白浆| 久久一区二区三区喷水| 欧美日韩亚洲三区| 日韩欧美字幕| 欧美一区=区| 麻豆网站免费在线观看| 91精品视频一区二区| 女人天堂亚洲aⅴ在线观看| 麻豆久久久久久| 亚洲欧洲日本mm| 另类小说一区二区三区| 另类激情亚洲| 91精品国产福利在线观看麻豆| 国产亚洲一区二区三区啪| 日韩视频一区| 91亚洲国产成人久久精品| 日韩高清不卡在线| 国产精品毛片| 91精品婷婷色在线观看| 黄色在线观看www|