我正在使用 Angular 5 并使用 subscribe() 方法订阅了一个 observable。我想知道是否只在订阅上调用 unsubscribe() 方法就足以清除所有内容,还是应该调用 remove() 方法?

代码片段:

`

// somewhere in a method
this.s1 = someObservable.subscribe((value) => {
     //somecode
 });
// in ngOnDestroy
this.s1.unsubscribe(); // should I also call .remove()

`

最佳答案

.remove 从内部列表中删除订阅,但它确实 而不是 取消订阅。.unsubscribe 清理所有内容,取消订阅并从内部列表中删除观察者。 (有一个错误(已修复)没有从列表中删除观察者).takeWhile 保持订阅,因为某种情况是 false例子:

this.service.method()
.subscribe(res => {
  //logic
});
这永远不会退订。
this.service.method()
    takeWhile(() => this.isAlive) // <-- custom variable setted to true
    .subscribe(res => {
      //logic
    });

ngOnDestroy(){
    this.isAlive = false;
}
当组件将被销毁时自动取消订阅。
   this.s1 = someObservable.subscribe((value) => {
        //somecode
    });

public yourMethod(){
    this.s1.unsubscribe();
}
此订阅将存在并“活着”,直到 yourFunction 未被调用。
——
我个人喜欢使用 rxjs 操作符 takeWhile 来保持代码整洁。在一个非常大的项目或具有多个订阅的单个组件中,拥有 (IE) 30 variables: Subscription 会令人困惑。所以如果你问什么时候使用 takeWhile 操作符,我的回答是:(以一个订阅为例)-> 如果你确定在组件销毁时需要完成 unsubscribe,请使用 takeWhile。如果在某个组件还“活着”的场景下需要退订,就用我写的第二个例子。
希望能澄清论点。

关于javascript - subscription.unsubscribe() 和 subscription.remove() 有什么区别?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/53428573/

10-12 12:28