首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在ngOnChanges中处理异步

如何在ngOnChanges中处理异步
EN

Stack Overflow用户
提问于 2017-06-22 20:40:17
回答 1查看 3.7K关注 0票数 2

我遇到了这个问题,我不知道如何对待async方法,因为ngOnChanges不支持async

你们怎么做才能让这一切发生?

当我将async应用于ngOnChanges时,它不起作用。返回值为Promise

代码语言:javascript
复制
@Component({
  moduleId: module.id,
  selector: 'search',
  templateUrl: 'search.template.html'
})
export class Search implments OnChanges {
  async queryArray(data: string): Promise<T> {
     //sample scripts.
     return ....;
  }
  ngOnChanges(changes: SimpleChanges) {
     let query: string = "red";
     let result: string[] = [];

     await this.queryArray(query).then(resp => result = resp);
  }

}

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-06-22 20:48:36

  • 将方法标记为async
  • 添加await以等待Promise的结果
  • 删除then,因为现在您可以在添加await后直接分配结果
  • 直接分配结果。

代码:

代码语言:javascript
复制
async ngOnChanges(changes: SimpleChanges) {
   let query: string = "red";
   let result: string[] = [];

   result = await this.queryArray(query);
}

还请注意,queryArray不需要标记为async,除非您也希望等待该方法的结果以进行进一步处理。如果它所做的只是创造和回报一个承诺,那么它就没有必要了。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44708997

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档