javascript - 如何仅在所有请求完成后才调用函数?

标签 javascript node.js fetch node-fetch

我目前正在使用 npm 包 request 生成一些请求,如下所示:

for (var i = 0; i < array.length; i++) {

    var options = {
        url: '...',
        headers: {
            '...'
        }
    };
    function callback(error, response, body) {

    };
    request(options, callback);

}


function toBeCalledWhenAllRequestsHaveFinished() {

}

我只是不知道如何仅在所有请求完成后调用 toBeCalledWhenAllRequestsHaveFinished()

应该做什么?

最佳答案

我强烈建议使用node-fetch包。

Reference to the original poster

<小时/> 使用 npm install node-fetch --save 安装 node-fetch

Make a promise-returning fetch that resolves to JSON

const fetch = require('node-fetch');
function fetchJSON(url) {
    // Add options
    var options = {
        headers: {
            '...'
        }
    };
    return fetch(url, options).then(response => response.json());
}

Build an array of promises from an array of URLs

let urls = [url1, url2, url3, url4];
let promises = urls.map(url => fetchJSON(url));

当所有 promise 都得到解决时,调用toBeCalledWhenAllRequestsHaveFinished()

Promise.all(promises).then(responses => toBeCalledWhenAllRequestsHaveFinished(responses));

关于javascript - 如何仅在所有请求完成后才调用函数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51083719/

相关文章:

javascript - 有没有办法从 javascript,meteor 中的文本文件导入字符串?

javascript - 在用户提交时使用 jQuery 提交 HTML 和 CSS 坐标和值

javascript - Discord.js/JS - 如果每个字符串都有指定的数字(级别排行榜),则按降序对字符串数组进行排序

javascript - 使用 fetch 的 React 组件不会从响应中填充状态

javascript - fetch 向后端发送错误的数据格式

android - 在android上 react native 获取网络请求失败

javascript - 开发服务器返回响应错误码: 500 react-native

java - Firefox 4 中的小程序问题

javascript - 尝试使用 Google Assistant 应用连接到服务器

node.js - Microsoft Graph API - 修补用户(应用程序 token 的权限问题)