我正在使用 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/