Yesterday, I wrote about some best practices around exposing a Signal in our Angular applications. Let’s now take a look at the two different ways a Signal can be updated.
set()
The easiest way to update a Signal is the set()
method. Nice and easy for basic data types such as strings or booleans:
data:image/s3,"s3://crabby-images/e50f6/e50f654a3b15c4b73bfb8fed663b204d8b119329" alt=""
update()
When the new value of a Signal depends on its previous value, update()
is the best method to use. This is the ideal method for a counter, for instance:
data:image/s3,"s3://crabby-images/7d6b7/7d6b79135fccd3ba65f0db9dc4c02a253fc48450" alt=""
Here is how to increment the counter based on its current value:
data:image/s3,"s3://crabby-images/98b37/98b37984c5eedf1c5032af56f0d2a9b5fc71ea4e" alt=""
TL;DR
- When you need to update a simple value (string, number, boolean), use
set()
. - If that new value is based on the previous one, use
update()
instead ofset()