Following our theme of lifecycle methods with ngOnChanges
and ngOnInit
, I want to give you another interesting trick to be notified when an @Input
value changes.
We’re already familiar with that syntax:
data:image/s3,"s3://crabby-images/17ea8/17ea88f352c22c2e70e1707920395f8b6a8a2036" alt=""
But what if instead of applying @Input
on a class property, we used it on a setter:
data:image/s3,"s3://crabby-images/5c194/5c194028f8bcaad734c078c2502984e97dac6966" alt=""
The input works the same as before, with the advantage of running several instructions when a new value is set. All of that without using ngOnChanges
. This approach is practical if you have several side-effects to trigger depending on which input changes, which would be tedious to handle with multiple conditionals:
data:image/s3,"s3://crabby-images/dd9aa/dd9aa27ecb4b368460f8d39ed179560631be407d" alt=""
The setter approach brings more clarity and leaves less room for mistakes:
data:image/s3,"s3://crabby-images/b7712/b7712769f9a6497bc1a3dca300b157c44e87b780" alt=""