【问题标题】:Multiple sync functions with inside async functions具有内部异步功能的多个同步功能
【发布时间】:2019-05-01 09:31:09
【问题描述】:

我对异步函数有一点问题(在 functionSync1 中有一个异步函数)。 我有这个代码:

main() {
    functionSync1();
    functionSync2();
}

functionSync1() {
    console.log('start');
    let promise = 
    Promise.resolve(this.localStorage.getItem('myItem').toPromise());
    promise.then((val) => console.log(val));
}

functionSync2() {
    console.log('end');
}

由于某些原因我不能修改main()的代码,所以我想修改functionSync1()以便等待函数结束,直到console.log(val)被执行。
现在console.log('end')console.log(val)之前执行,所以输出为:

start
end
myItemValue

我需要这个:

start
myItemValue
end

有什么想法吗?

【问题讨论】:

  • 如果你不能改变main,那是不可能的。

标签: javascript angular function asynchronous


【解决方案1】:

您可以使用承诺队列创建您描述的输出:

  const queue = Promise.resolve();

  function enqueue(task, ...args) { return queue = queue.then(() => task(...args)); }

  functionSync1(){
    console.log('start');
    enqueue(() => this.localStorage.getItem('myItem').toPromise())
      .then((val) => console.log(val));
  }



  functionSync2(){
    enqueue(() => console.log('end'));
  }

但是你真的应该改变main。其他一切都是一种解决方法。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2022-01-25
    • 2015-02-10
    • 2022-10-21
    • 1970-01-01
    • 2021-09-23
    相关资源
    最近更新 更多