Angular 16 introduced several features related to the brand-new Angular Signals, which include two functions enabling RxJs interoperability.
toObservable()
The name says it all. toObservable()
takes a Signal and returns its data as an Observable:
data:image/s3,"s3://crabby-images/62ebe/62ebe2709bfaed7089632bd94df299dadd5f903a" alt=""
This new Observable gets updated every time the underlying Signal value is updated. We can subscribe to it using the async pipe, for instance (demo code here):
data:image/s3,"s3://crabby-images/95203/95203154231a2218adc4eecc3b0a58917ff9a96a" alt=""
toSignal()
toSignal()
does the opposite of toObservable()
. It turns an Observable into a Signal. Since Signals are different from Observables (a Signal always has a value right from the start – an Observable does not), the default behavior of toSignal()
is to return a Signal that supports undefined
as a default value:
data:image/s3,"s3://crabby-images/9376f/9376f9b76df74d81f1b76428bb89d3dd8992b4a2" alt=""
This can be changed by providing an initial value as follows:
data:image/s3,"s3://crabby-images/63bfa/63bfacee3093ab78c689f879b959fd018e36336d" alt=""