从此用 RxJS 订阅的时候,时刻都不忘调用 unsubscribe() 以防内存泄漏。对于结束 Observable,释放内存的方式有三种方式:
第一种,Observable 完成值的发送,执行 Observable.onComplete()
第二种,Observable 发生错误,执行 Observable.OnError()
第三种,订阅者主动取消订阅,执行 subscription.unsubscribe()
对于Observable.onComplete()和Observable.OnError(),RxJS 自身会处理这两种情况,所以不需要在代码里再手动取消订阅释放内存。
在 Angular 项目中,常用到的订阅以及是否需要调用 unsubscribe() 取消订阅,有以下几种:
-
Angular 中通过 HttpClient 执行 Http Request 返回的 Observables,订阅这些 Observables 拿到 API 返回的数据,不需要调用 unsubscribe() 取消订阅。
-
Angular AsyncPipe,不需要调用 unsubscribe()取消订阅。(内置自动销毁)
Angular内置AsyncPipe解析 -
RxJS 自带的一些操作符:take,takeWhile,first 等等,不需要调用 unsubscribe()取消订阅。(内置自动销毁)
- <