工做中遇到一个问题ios
for循环,再把循环出来的ID再进行二次请求axios
这就致使一个问题数组
请求结果返回顺序不一致promise
缘由:异步请求会把回调事件放入微任务事件队列,宏任务执行完毕再执行微任务,具体参考事件队列机制dom
解决方法:异步
经过map方法进行循环请求ide
将异步请求方法封装起来,返回一个promisecode
这样将会返回一个具备多个promise的数组队列
经过promise.all()方法把promise包装成一个新的promise实例事件
// 经过Promise把全部的异步请求放进事件队列中 getInfo(item ,index) { const ms = 1000 * Math.ceil(Math.random() * 3) return new Promise((resolve,reject) => { setTimeout(() => { axios.get(id).then((result) => { resolve(result) }) }, ms) }) } // 返回多个promise let promise = arr.map((item,index) = > { arr.forEach((item, index) => { return getInfo(item, index) }) }) // 对返回的promise数组进行操做 Peomise.all(promise).then((allData) => { arr.forEach((item, index) => { // ...... }) })