电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

利用js實現(xiàn)Ajax并發(fā)請求限制請求數(shù)量的示例代碼

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

出現(xiàn)問題描述:當(dāng)不確定異步請求個數(shù)時,為防止當(dāng)一瞬間發(fā)生上百個http請求時,導(dǎo)致堆積了無數(shù)調(diào)用棧進(jìn)而導(dǎo)致內(nèi)存溢出問題。

要求:將同一時刻并發(fā)請求數(shù)量控制在3個以內(nèi),同時還要盡可能快速的拿到響應(yīng)的結(jié)果。

同面試問題:

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

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

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

串行:一個異步請求完成了之后再進(jìn)行下一個請求

并行:多個異步請求同時進(jìn)行

示例:串行

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保證數(shù)組中所有promise對象都達(dá)到resolve狀態(tài),才執(zhí)行then回調(diào)

Promise.all并發(fā)限制

含義: 指每個時刻并發(fā)執(zhí)行的promise數(shù)量是固定的,最終執(zhí)行的結(jié)果還是保持與原來的promise.all一致。

思路與實現(xiàn)

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

代碼實現(xiàn):

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

代碼實現(xiàn):

// 任務(wù)列表->新建任務(wù) 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: '服務(wù)連接錯誤 ' + item.name + ' 未上傳成功', });.finally(() => { uploadThreadNums--; resultFinishNum++; upload(); ); })(sendFinishNum); uploadThreadNums++; sendFinishNum++; } }; var creatTask = function () { axios.all(tasks).then((res) => { // 新建上傳任務(wù) /* 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(); },

到此這篇關(guān)于利用js實現(xiàn)Ajax并發(fā)請求限制請求數(shù)量的示例代碼的文章就介紹到這了,更多相關(guān)js Ajax并發(fā)請求限制內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 天津热油泵_管道泵_天津高温热油泵-天津市金丰泰机械泵业有限公司【官方网站】 | 上海新光明泵业制造有限公司-电动隔膜泵,气动隔膜泵,卧式|立式离心泵厂家 | 半自动预灌装机,卡式瓶灌装机,注射器灌装机,给药器灌装机,大输液灌装机,西林瓶灌装机-长沙一星制药机械有限公司 | 硫化罐-电加热蒸汽硫化罐生产厂家-山东鑫泰鑫智能装备有限公司 | 六维力传感器_三维力传感器_二维力传感器-南京神源生智能科技有限公司 | 披萨石_披萨盘_电器家电隔热绵加工定制_佛山市南海区西樵南方综合保温材料厂 | 洛阳防爆合格证办理-洛阳防爆认证机构-洛阳申请国家防爆合格证-洛阳本安防爆认证代办-洛阳沪南抚防爆电气技术服务有限公司 | 水压力传感器_数字压力传感器|佛山一众传感仪器有限公司|首页 | 合肥白癜风医院_[治疗白癜风]哪家好_合肥北大白癜风医院 | 全自动面膜机_面膜折叠机价格_面膜灌装机定制_高速折棉机厂家-深圳市益豪科技有限公司 | 许昌奥仕达自动化设备有限公司 | 学校用栓剂模,玻璃瓶轧盖钳,小型安瓿熔封机,实验室安瓿熔封机-长沙中亚制药设备有限公司 | 软文世界-软文推广-软文营销-新闻稿发布-一站式软文自助发稿平台 | 流量卡中心-流量卡套餐查询系统_移动电信联通流量卡套餐大全 | 一体化污水处理设备-一体化净水设备-「山东梦之洁水处理」 | 同学聚会纪念册制作_毕业相册制作-成都顺时针宣传画册设计公司 | 航空铝型材,7系铝型材挤压,硬质阳*氧化-余润铝制品 | 东莞压铸厂_精密压铸_锌合金压铸_铝合金压铸_压铸件加工_东莞祥宇金属制品 | 罗氏牛血清白蛋白,罗氏己糖激酶-上海嵘崴达实业有限公司 | 天津电机维修|水泵维修-天津晟佳机电设备有限公司 | 爱佩恒温恒湿测试箱|高低温实验箱|高低温冲击试验箱|冷热冲击试验箱-您身边的模拟环境试验设备技术专家-合作热线:400-6727-800-广东爱佩试验设备有限公司 | 食品级焦亚硫酸钠_工业级焦亚硫酸钠_焦亚硫酸钠-潍坊邦华化工有限公司 | 集装箱标准养护室-集装箱移动式养护室-广州璟业试验仪器有限公司 | 上海单片机培训|重庆曙海培训分支机构—CortexM3+uC/OS培训班,北京linux培训,Windows驱动开发培训|上海IC版图设计,西安linux培训,北京汽车电子EMC培训,ARM培训,MTK培训,Android培训 | 工控机,嵌入式主板,工业主板,arm主板,图像采集卡,poe网卡,朗锐智科 | 高压绝缘垫-红色配电房绝缘垫-绿色高压绝缘地毯-上海苏海电气 | 武汉不干胶印刷_标签设计印刷_不干胶标签印刷厂 - 武汉不干胶标签印刷厂家 | 华禹护栏|锌钢护栏_阳台护栏_护栏厂家-华禹专注阳台护栏、楼梯栏杆、百叶窗、空调架、基坑护栏、道路护栏等锌钢护栏产品的生产销售。 | 深圳网站建设-高端企业网站开发-定制网页设计制作公司 | 陕西华春网络科技股份有限公司 | 越南专线物流_东莞国际物流_东南亚专线物流_行通物流 | 电伴热系统施工_仪表电伴热保温箱厂家_沃安电伴热管缆工业技术(济南)有限公司 | 聚合氯化铝厂家-聚合氯化铝铁价格-河南洁康环保科技 | 武汉印刷厂-不干胶标签印刷厂-武汉不干胶印刷-武汉标签印刷厂-武汉标签制作 - 善进特种标签印刷厂 | 工业设计,人工智能,体验式3D展示的智能技术交流服务平台-纳金网 J.S.Bach 圣巴赫_高端背景音乐系统_官网 | 沈飞防静电地板__机房地板-深圳市沈飞防静电设备有限公司 | 武汉天安盾电子设备有限公司 - 安盾安检,武汉安检门,武汉安检机,武汉金属探测器,武汉测温安检门,武汉X光行李安检机,武汉防爆罐,武汉车底安全检查,武汉液体探测仪,武汉安检防爆设备 | 青岛侦探调查_青岛侦探事务所_青岛调查事务所_青岛婚外情取证-青岛狄仁杰国际侦探公司 | 防爆电机_防爆电机型号_河南省南洋防爆电机有限公司 | 长沙发电机-湖南发电机-柴油发电机供应厂家-长沙明邦智能科技 | 耐火砖厂家,异形耐火砖-山东瑞耐耐火材料厂 |