RxJS: Hot and Cold Observables
data:image/s3,"s3://crabby-images/6c0fa/6c0fa4733d024edab1fea4df8a6248eda51bd543" alt=""
Zenab Saleem
data:image/s3,"s3://crabby-images/f6fe9/f6fe97f009383217448eff3c69253e754613aa92" alt=""
/zenabSaleemKhan
data:image/s3,"s3://crabby-images/ed8f6/ed8f668812973285b4103fbd5dfee253e18700f6" alt=""
/zenabKhan
data:image/s3,"s3://crabby-images/59dd4/59dd491b2eff2e439b08a0ddff058c21671f2cb9" alt=""
Lead Developer
Recurship
data:image/s3,"s3://crabby-images/fcb57/fcb5708f1b974924e7b91b2e245b78e4da7a296c" alt=""
data:image/s3,"s3://crabby-images/29068/2906877664268b271a71ed934a0cd34711a10eb4" alt=""
zainabslm@gmail.com
What is RxJS?
RxJS is a library for reactive programming using Observables, to make it easier to compose asynchronous or callback-based code.
What is an Observable?
A representation of any set of values over any amount of time. This the most basic building block of RxJS.
What is an Observable? (cont.)
data:image/s3,"s3://crabby-images/80ce7/80ce7af6795f63390bb17206f9f96c0d93b941b0" alt=""
- Array of values over an amount of time.
- A data stream
- Just a function, with a few special characteristics.
- It takes in an “observer” (an object with “next”, “error” and “complete” methods on it)
- Returns cancellation logic (unsubscribe)
- Connects observer to "producer"(source of values)
What is an Observable? (cont.)
- Observables can be either hot or cold
- Observables created using the of, from, range, interval and timer operators will be cold.
- Observables created with the fromEvent operator for either user events or WebSocket events will be hot.
Cold Observable
- Producer created by the observable inside it
- Data emits on subscribe to observable
- Completes data stream itself
- Unicasts
- All subscriptions are independent
- Re-emits the whole values for new subscriber
data:image/s3,"s3://crabby-images/398ba/398bab419ea60003b6dc2c19b56a4f660d11569e" alt=""
Hot Observable
- Producer created outside the observable
- Data emits as soon as observable created
- need extra logic to complete the subscription
- Multicasts
- All subscriptions share values
- Data can be lost if no subscriber
data:image/s3,"s3://crabby-images/a9fee/a9feea026f19bb350d12e1f7af253757c27a92e7" alt=""
Making cold observable hot
Example 1
Example 2
Publish
publish() : ConnectableObservable
???? Observable
Warm Observable
- Start emitting when at least one subscriber
- Publish() along with refCount()
- Shortcut share()
Summary
- Hot observable -> Movie at the Cinema
- Cold observable -> Movie with Netflix
- ‘Warm’ observable -> Movie with friends
Useful links
-
Hot vs Cold Observables - Ben Lesh
-
Hot vs Cold Observables for Angular - Youtube video
-
RxJS: Hot And Cold Observables - alligator.io
-
COLD VS HOT OBSERVABLES - Christoph Burgdorf
-
RxJS: Observables and Observers - Todd Motto
Thank you :)
RXJS: Hot and Cold Observables
By Zenab Saleem
RXJS: Hot and Cold Observables
- 2,559