如何在ngOnChanges中处理异步

时间:2017-06-22 20:40:17

标签: angular

我遇到了这个问题而我没有看到如何对待async方法,因为ngOnChanges不支持async

你们做了什么来实现这一目标?

async应用于ngOnChanges时,它无效。返回值为Promise

@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);
  }

}

1 个答案:

答案 0 :(得分:1)

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

代码:

async ngOnChanges(changes: SimpleChanges) {
   let query: string = "red";
   let result: string[] = [];

   result = await this.queryArray(query);
}

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