实现批量请求函数

发布于 2023-05-05 13:02:48 字数 1254 浏览 66 评论 0

实现一个批量请求函数 multiRequest(urls, maxNum)

要求如下:

  1. 要求最大并发数 maxNum
  2. 每当有一个请求返回,就留下一个空位,可以增加新的请求
  3. 所有请求完成后,结果按照 urls 里面的顺序依次打出

答案一

function multiRequest(urls, maxNum) {
    let results = new Array(urls.length).fill(null); // 用于存放请求结果 
    let currentIndex = 0; // 当前请求的索引
    let activeCount = 0; // 当前正在进行的请求个数

    function handleRequest(url, index) {
        activeCount++; // 当前正在进行的请求个数加1

        fetch(url)
            .then(response => response.json())
            .then(data => {
                results[index] = data; // 存储请求结果
                activeCount--; // 当前正在进行的请求个数减1
                if (currentIndex < urls.length) {
                    handleRequest(urls[currentIndex], currentIndex); // 继续进行下一个请求
                    currentIndex++;
                }
                if (activeCount === 0) {
                    console.log(results); // 所有请求完成后,按照 urls 里面的顺序依次打出结果
                }
            })
            .catch(error => console.error(error));
    }

    while (currentIndex < urls.length && currentIndex < maxNum) {
        handleRequest(urls[currentIndex], currentIndex);
        currentIndex++;
    }
}

调度器版本

也可以通过实现一个调度器进行实现

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

流殇

暂无简介

0 文章
0 评论
22 人气
更多

推荐作者

qq_eQNo9e

文章 0 评论 0

内心旳酸楚

文章 0 评论 0

mb_BlPo2I8v

文章 0 评论 0

alipaysp_ZRaVhH1Dn

文章 0 评论 0

alipaysp_VP2a8Q4rgx

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文