You’re probably familiar with ngOnDestroy for Angular components/pipes/directives, which cleans things up when an Angular object is destroyed. A typical use case is to unsubscribe from RxJs subscriptions (though there are better-suited tools for this now) or cancel a timer.
Angular Signals introduced the effect() function to run side-effects, including RxJs Observables or timers. As a result, we might want to cancel a timer or an RxJS-based task when the effect runs again in the future, and luckily for us, Angular supports a cleanup function for our effects.
To enable the cleanup function, we pass it as a parameter to the callback registered in our effect:
data:image/s3,"s3://crabby-images/30a9d/30a9d2fe3b2a60c711bfa41cc21264e9a43f2ca4" alt=""
Then we call it and pass our cleanup code as a param to it using an arrow function:
data:image/s3,"s3://crabby-images/f4c7b/f4c7b8a9156bdd46ea2e4c7888e4de9aec5cf50e" alt=""
Here is the full example in action on Stackblitz. This example destroys a component and clears its timer thanks to the effect cleanup function:
data:image/s3,"s3://crabby-images/7bd7a/7bd7a7454aca06ac76826dc003addaa66559f150" alt=""