视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
解决for循环中异步请求顺序不一致的问题
2020-11-03 18:22:44 责编:小采
文档


解决for循环中异步请求顺序不一致的问题

工作中遇到一个问题

for循环,再把循环出来的ID再进行二次请求

这就导致一个问题

请求结果返回顺序不一致

原因:异步请求会把回调事件放入微任务事件队列,宏任务执行完毕再执行微任务,具体参考事件队列机制

【相关课程推荐:JavaScript视频教程】

解决方法:

通过map方法进行循环请求

将异步请求方法封装起来,返回一个promise

这样将会返回一个具有多个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) => {
 // ......
 })
})

本文来自 js教程 栏目,欢迎学习!

下载本文
显示全文
专题