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/6863b/6863b9dbb0eca3c99177e82e1259ac57d3c9fea4" alt="Subscription property definition dialog"
And add an unsubscribe UI method to clean it up:
data:image/s3,"s3://crabby-images/1f8ca/1f8cadafbdfab7a4aa0851dd910874872dd5558a" 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/460eb/460eb62a101622fdd111f1423fb9a997ae7313b4" 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!