问题遇到的现象和发生背景
使用 async和await时,在里面调用了异步函数,在接收返回的对象d后打印对象d数据是全的,但是使用时对象d里的children属性却还没获取到显示undefined
问题相关代码,请勿粘贴截图
function getData(d){
return new Promise((resolve,reject)=>{
d.forEach(element => {
api(element).then(res=>{
element.children = res.nodes
})
});
console.log('第一个打印')
resolve(d)
})
}
async function click(d){
var data = await getData(d)
console.log(data) //数据是全的 有data.children属性
console.log('第二个打印')
data.forEach(collapse)
}
function collapse(d){
// console.log(d.children)在这里打印时 d.children 为undefined
if(d.children){
}
}
我的解答思路和尝试过的方法
在 click事件中加个定时器就可以了
async function click(d){
var data = await getData(d)
console.log(data) //数据是全的 有data.children属性
console.log('第二个打印')
setTimeout(()=>{
data.forEach(collapse)
},1000)
}
我想要达到的结果
请问async await 不就是相当于把异步转为同步吗 为什么打印顺序都是对的 但是数据返回的结果不对 不是同步的呢