首页 > web前端 > js教程 > 如何处理 Angular 中可观察对象的异步响应?

如何处理 Angular 中可观察对象的异步响应?

Barbara Streisand
发布: 2024-12-24 02:16:10
原创
262 人浏览过

How Do I Handle Asynchronous Responses from Observables in Angular?

如何从 Angular 中的 Observable/http/async 调用返回响应?

问题:

从 Angular 中的服务器检索数据如果尝试使用 Observable 可能会导致未定义的初始值

服务:

@Injectable()
export class EventService {
  ...
  getEventList(): Observable<any> {
    ...
    return this.http.get(...).map(...).catch(...);
  }
}
登录后复制

组件:

export class EventComponent {
  myEvents: any;
  ngOnInit() {
    this.es.getEventList().subscribe((response) => {
      this.myEvents = response;
    });
    console.log(this.myEvents); // Initially undefined
  }
}
登录后复制

原因:

HTTP 请求是异步的,意味着 console.log( this.myEvents) 行在响应之前执行

解决方案:

仅在响应到达后使用订阅回调处理响应。

ngOnInit() {
  this.es.getEventList().subscribe((response) => {
    this.myEvents = response;
    console.log(this.myEvents); // Not undefined
  });
}
登录后复制

注意事项:

  • 执行当数据订阅回调中的所有操作
  • 认识到异步操作可以防止接口在等待响应时冻结。
  • 这种方法类似于基于 Promise 的异步编程中的 then 回调。

以上是如何处理 Angular 中可观察对象的异步响应?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板