要将axios.get多个响应结果包装到一个数组中,可以使用Promise.all()方法来实现。
Promise.all()方法接收一个包含多个Promise对象的数组作为参数,并返回一个新的Promise对象。这个新的Promise对象在所有的Promise对象都成功解析后才会被解析,如果其中任何一个Promise对象被拒绝,则新的Promise对象会被拒绝。
下面是一个示例代码:
const axios = require('axios');
const urls = ['url1', 'url2', 'url3']; // 假设有三个请求的URL
const requests = urls.map(url => axios.get(url)); // 使用axios.get()发送请求,并将返回的Promise对象存入数组
Promise.all(requests)
.then(responses => {
// responses是一个包含所有响应结果的数组
console.log(responses);
})
.catch(error => {
// 处理错误
console.error(error);
});
在上面的代码中,我们首先定义了一个包含多个请求URL的数组。然后,使用数组的map()方法遍历每个URL,调用axios.get()发送请求,并将返回的Promise对象存入一个新的数组requests中。
接下来,我们使用Promise.all(requests)来等待所有的请求都完成。当所有的请求都成功解析后,Promise.all()返回一个包含所有响应结果的数组responses。我们可以在.then()回调函数中对这个数组进行处理。
如果其中任何一个请求被拒绝(即出现错误),则Promise.all()会立即将新的Promise对象标记为被拒绝,并将错误传递给.catch()回调函数进行处理。
这种方法适用于需要同时发送多个请求,并且希望在所有请求完成后进行处理的场景。
领取专属 10元无门槛券
手把手带您无忧上云