欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

javascript for循环+异步请求导致请求顺序不一致

程序员文章站 2022-03-21 17:25:31
工作中遇到一个问题 for循环,再把循环出来的ID再进行二次请求 这就导致一个问题 请求结果返回顺序不一致 原因:异步请求会把回调事件放入微任务事件队列,宏任务执行完毕再执行微任务,具体参考事件队列机制 解决方法: 通过map方法进行循环请求 将异步请求方法封装起来,返回一个promise 这样将会 ......

工作中遇到一个问题

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

这就导致一个问题

请求结果返回顺序不一致

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

 

解决方法:

通过map方法进行循环请求

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

这样将会返回一个具有多个promise的数组

通过promise.all()方法把promise包装成一个新的promise实例

 1 // 通过promise把所有的异步请求放进事件队列中
 2 getinfo(item ,index) {
 3     const ms = 1000 * math.ceil(math.random() * 3)
 4     return new promise((resolve,reject) => {
 5         settimeout(() => {
 6            axios.get(id).then((result) => {
 7                resolve(result)
 8            })
 9         }, ms)
10     })
11 }
12 
13 // 返回多个promise
14 let promise = arr.map((item,index) = > {
15     arr.foreach((item, index) => {
16         return getinfo(item, index)
17     })
18 })
19 // 对返回的promise数组进行操作
20 peomise.all(promise).then((alldata) => {
21     arr.foreach((item, index) => {
22         // ......
23     })
24 })