js遍历一个数组,怎么在每次遍历的时候发送一个异步请求,然后请求成功后在进行下一步循环(主要是下一步循环调请求的时候需要使用上一次请求的数据),在线急等!!
js遍历一个数组,怎么在每次遍历的时候发送一个异步请求,然后请求成功后在进行下一步循环(主要是下一步循环调请求的时候需要使用上一次请求的数据),在线急等!!
//
function traverse (arr) {
let i = 0
let len = arr.length
return function recursion (d) {
if (i >= len) return Promise.resolve(d) // 最后一次请求的结果
let data = arr[i++]
// let params = { // data是循环的数据,d是上次请求返回的数据
// data,
// d
// }
return new Promise((resolve, reject) => { // promise替换成你的异步请求
setTimeout(() => {
resolve(data + d)
}, 1000)
}).then(d => { // 处理请求后的数据
console.log(d)
recursion(d) // 把请求后的数据传给下一次调用
})
}
}
var arr = [1, 2, 3, 4]
var fun = traverse(arr)
fun(0).then(console) // 打印最后一次请求的结果
async function foo() {
const time1 = 100;
const time2 = await step1(time1);
const time3 = await step2(time2);
}
step里return Promise对象
13 回答13.1k 阅读
7 回答2.3k 阅读
3 回答1.4k 阅读✓ 已解决
6 回答1.5k 阅读✓ 已解决
2 回答1.5k 阅读✓ 已解决
3 回答1.5k 阅读✓ 已解决
2 回答1.7k 阅读✓ 已解决
你可能需要了解一下数组迭代器。。。
上面说的有点偏题,其实楼主的问题,上面已经给了答案,只不过答案来的太直接,楼主其实想串行执行一个与数组元素对应的方法,那就是个异步队列,那这个的话,promise是最佳人选啊。