Angular use observables to pass values that change over time. A common example is listening to the current path of the app:
this.router.events.subscribe((event) => {
if (event instanceof NavigationEnd) {
debug('this.router.url',this.router.url);
}
})
If you call a .subscribe method like the example above, you can cause a memory leak. You need to be sure to unsubscribe when your UI is unloaded.
Single Subscription
If your component only uses one subscription, you can add a subscription property to your UI:
data:image/s3,"s3://crabby-images/75821/758215702bffc4f8039dc12aa11559ea74743939" alt="Subscription property definition dialog"
And add an unsubscribe UI method to clean it up:
data:image/s3,"s3://crabby-images/c37a2/c37a2d58f6580079906a05bbe25ebfef170f6847" alt="Unsubscribe method dialog window"
Multiple Subscriptions
If your app uses more than one subscription, you can make the property subscriptions:
data:image/s3,"s3://crabby-images/9b681/9b681112daa710e127aa1ca35e745b3482c36511" alt="Property definition dialog"
And subscribe to the observable like this:
this.subscriptions.push(
this.router.events.subscribe((event) => {
if (event instanceof NavigationEnd) {
debug('this.router.url',this.router.url);
}
})
);
And make the unsubscribe method like this:
while (this.subscriptions.length > 0) {
this.subscriptions.pop().unsubscribe();
}
You can use the multiple pattern for a single subscription as well. You never know when you might need to add another!