let arr = []
result.map(async v => {
let b = await ctx.service.center.getDetails(id)
arr.push(b)
}
之后打印arr是个空数组,所以还是存在异步问题
首先想到的是,把promise存到数组,然后用Promise.all()把数据搞定
let arr = []
result.map(async v => {
let b = ctx.service.center.getDetails(id)
arr.push(b)
}
Promise.all(arr).then(r => console.log(r))
然后了解了map遍历后直接会获取到数组
let arr = result.map(async v => {
return ctx.service.center.getDetails(id)
}
Promise.all(arr).then(r => console.log(r))
最后全部简写
const arr = await Promise.all(result.map(v => ctx.service.center.getDetails(id)))
Promise.all()方法,返回的实例就是传入他里面的所有Promise的完成状态 https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Promise/all
扫码关注腾讯云开发者
领取腾讯云代金券
Copyright © 2013 - 2025 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287
Copyright © 2013 - 2025 Tencent Cloud.
All Rights Reserved. 腾讯云 版权所有