js异步return

有点理不清异步return的逻辑,b函数里把a函数的返回值打印,a函数的返回值是异步得到的,所以一开始会得到空数组,怎么修改能使得data不为空之后再return出来呀

        function a(){
            console.log('a');
            var data=[];
            setTimeout(function (){
                data.push([1]);
            },1000);
            return data;
        }
        
        function b(){
            console.log('b');
            var d=a();
            console.log(d);
        }

        b();
阅读 9.6k
3 个回答

用回调函数通知或者使用 async function

function getData(callback) {
  const data = []
  console.info(data)
  setTimeout(_ => {
    data.push(+new Date())
    typeof callback === 'function' && callback(data)
  }, 1e3)
}

getData(data => console.info(data))
async function getData() {
  const sleep = delay => new Promise(resolve => setTimeout(resolve, delay || 0))
  const data = []
  console.info(data)
  await sleep(1000)
  data.push(+new Date())
  return data
}

;(async _ => {
  console.info(await getData())
})()
function a(solve){
    console.log('a');
    var data=[];
    setTimeout(function (){
       data.push([1]);
       solve(data);
    },1000);
}
function b(data){
   console.log(data);
}
new Promise(a).then(b);

通过Promise来解决吧。

function a() {
    console.log('a');
    var data = [];
    return new Promise(function(resolve, reject){
      setTimeout(function() {
          data.push([1]);
          resolve(data);
      }, 1000);
    })
}

function b() {
    console.log('b');
    var d = a().then(function(data){
      console.log(data);
    })
}

b();
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题