国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

node.js|vue.js|jquery|angularjs|React|json|js教程|

香港云服务器
服務器之家 - 編程語言 - JavaScript - js教程 - 利用js實現Ajax并發請求限制請求數量的示例代碼

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

2022-02-24 16:48GuaX js教程

這篇文章主要介紹了利用js實現Ajax并發請求限制請求數量的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

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

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

同面試問題:

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

  • 要求最大并發數 maxNum
  • 每當有一個請求返回,就留下一個空位,可以增加新的請求
  • 所有請求完成后,結果按照 urls 里面的順序依次打出

1、基于Promise.all實現Ajax的串行和并行

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

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

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

示例:串行

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
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')
})

 并行:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
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,保證最后輸出的順序不會亂,而是依次輸出

代碼實現:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
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();
     }
    });
  }
 });
}

代碼實現:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
// 任務列表->新建任務
 
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并發請求限制內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://blog.csdn.net/m0_37714008/article/details/112462983

延伸 · 閱讀

精彩推薦
  • js教程原生js拖拽功能制作滑動條實例代碼

    原生js拖拽功能制作滑動條實例代碼

    這篇文章主要介紹了原生js拖拽功能制作滑動條實例教程,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的...

    蔣偉平3522022-01-17
  • js教程JS實現頁面側邊欄效果探究

    JS實現頁面側邊欄效果探究

    這篇文章主要介紹了JS實現頁面側邊欄效果探究,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以...

    行舟客5132021-12-29
  • js教程如何在現代JavaScript中編寫異步任務

    如何在現代JavaScript中編寫異步任務

    這篇文章主要給大家介紹了關于如何在現代JavaScript中編寫異步任務的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考...

    瘋狂的技術宅11842022-01-12
  • js教程微信小程序選擇圖片控件

    微信小程序選擇圖片控件

    這篇文章主要為大家詳細介紹了微信小程序選擇圖片控件,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    小雅雅家的小凱凱吖9972022-01-04
  • js教程JS實現隨機點名系統

    JS實現隨機點名系統

    這篇文章主要為大家詳細介紹了JS實現隨機點名系統,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    乘風破浪的程序媛3462022-02-22
  • js教程一篇文章告訴你JavaScript 如何實現繼承

    一篇文章告訴你JavaScript 如何實現繼承

    JavaScript 在編程語言界是個特殊種類,它和其他編程語言很不一樣,JavaScript 可以在運行的時候動態地改變某個變量的類型。...

    Python進階學習交流5482022-02-19
  • js教程四個Javascript 中的 For 循環

    四個Javascript 中的 For 循環

    在 ECMAScript5(簡稱 ES5)中,有三個循環。在 2015 年 6 月發布的 ECMAScript6(簡稱 ES6)中,新增了一種循環類型。...

    鋒享前端4722022-01-12
  • js教程JavaScript代碼實現簡單日歷效果

    JavaScript代碼實現簡單日歷效果

    這篇文章主要為大家詳細介紹了JavaScript代碼實現簡單日歷效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    乘風破浪的程序媛4302022-02-23
792
主站蜘蛛池模板: 国产成人毛片 | 国产精品久久久久久久9999 | 久久国产精品一区 | 国产综合亚洲精品一区二 | 久久精彩 | 精品三级 | 久久精品无码一区二区三区 | 亚洲网站在线观看 | 中文字幕视频二区 | 亚洲一区二区三区高清 | 久久久精品网 | 久久精品噜噜噜成人av农村 | 日韩午夜| 日韩精品网站 | 97伦理在线 | 国产伦精品一区二区三区四区视频 | 精品无码久久久久久久动漫 | 国产人妖视频 | 日韩电影一区二区三区 | 国产精品久久 | 国产视频中文字幕 | 国产精品久久久久久久久软件 | 久久亚| 中文字幕一区二区三区四区五区 | 久久久久亚洲精品 | 成人av高清在线观看 | 日韩一二三区视频 | 欧美视频成人 | 久久久婷婷| 久久99久久99精品免观看粉嫩 | 精品久久一二三区 | 亚洲精品日日夜夜 | 国产精品剧情一区二区三区 | 男女18免费网站视频 | 亚洲国产成人精品女人久久久 | 欧美成人激情视频 | 中文字幕一区二区三区日韩精品 | 91视频观看 | 国产精品久久久久久久久久久久 | 久久久久国产 | 国产一级纯肉体一级毛片 |