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

互联网 19-12-17

解决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教程 栏目,欢迎学习!

以上就是解决for循环中异步请求顺序不一致的问题的详细内容,更多内容请关注技术你好其它相关文章!

来源链接:
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表本站的观点或立场
标签: 异步请求
上一篇:php获取远程图片并下载保存到本地的方法分析 下一篇:巧妙的给div、p标签添加onload事件

相关资讯