繁体   English   中英

如何最好地在 Angular2 中使用 takeUntil 取消订阅 observable

[英]Hows best to unsubscribe from an observable using a takeUntil in Angular2

如何最好地使用 takeUntil 取消订阅 observable。

据我所知,takeUntil 会自动为您完成。

以下是我通常如何取消订阅 observable。 但不确定是否正确完成。 我真的需要“this.destroyed$.complete();”吗? 如果 takeUntil 对我来说完成了吗?

这是我目前的尝试,但不确定是否是最佳方法:

 private destroyed$: Subject<void> = new Subject();

 ngOnIt(): void {
    this.serviceA.getData
      .takeUntil(this.$destroyed)
      .subscribe(val => {
        console.log('Current value:', val);
      });
  };

  ngOnDestroy(): void {
    this.destroyed$.next();
    this.destroyed$.complete();
  };

我正在考虑删除 ngOnDestory 中的 .complete 但不确定这是否会导致内存泄漏?

我个人更喜欢这个解决方案,有另一个主题只是为了处理取消订阅并与 takeUntil 混淆可能会使事情变得太复杂

 private _subscriptions:Subscription[];

 ngOnIt(): void {
  this._subscriptions.push(this.serviceA.getData
  .subscribe(val => {
    console.log('Current value:', val);
  })
   )
};

ngOnDestroy(): void {
this._subscriptions.foreach(subs=>{ subs.unsubscribe()})
};

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM