We know how to create a State and dispatch actions to update its value. Now let’s see how to receive updates when the State gets updated.
Most state management libraries provide what is known as Selectors. A Selector query function runs against our State and returns an Observable. For instance, with NgXs, a Selector can be created with the @Select
decorator as follows:
data:image/s3,"s3://crabby-images/f565a/f565a13d021a74a046b8124d1f6db87b037de24c" alt=""
The above code creates an Observable that returns any value update in state.currencyInfo
. If you don’t like decorators, you can also use the select
function from the Store service:
data:image/s3,"s3://crabby-images/a94a4/a94a432ce742988c20d9c8d683f9c7fae46ec787" alt=""
Both options return a similar Observable. If a Selector of a slice of your State is used repeatedly, you can make it a memoized selector by using the @Selector
decorator in your State class. This example creates a new selector that returns just the currency property of our State:
data:image/s3,"s3://crabby-images/16811/16811fdb19bb200a8073430c8bc5161589f8b569" alt=""
Such a Selector can be used with @Select decorator in your components/services as follows:
data:image/s3,"s3://crabby-images/6255d/6255da9eff5fdd2eccf5c48983548c76f388fed0" alt=""
You can see that code in action on Stackblitz.