Building a Stock Ticker
Let's build a stock ticker project, which displays stock prices in real-time.
We'll cover the following
Stock ticker project
In the previous few lessons, we built a typeahead. It covers only one kind of asynchronous flow. The frontend always triggers the initiating event and then waits for a response.
The backend never provides new data unless the frontend specifically asks for it.
In the next few lessons, you’re going to build a stock market viewer, which will display the (randomly-generated) prices of several fake stocks in real-time.
The server will send data to the frontend at any time, and the code needs to be ready to react to new events. In addition, the Rx stream needs to track the current state of each stock ticker for display on the page.
As a cherry on top to let you really flex your Rx muscles, we’ll add some on-page filters that require their own streams.
Constructor for web sockets
This is your biggest challenge yet. The first thing to write is the constructor. A constructor that’s specifically built for WebSockets in RxJS:
let endpoint = 'ws://localhost:3000/api/advancedAsync/stock-ws';
// No semicolon at the end here - this is continued in the next snippet
let stockStream$ = webSocket(endpoint)
📝 Subjects
stockStream$
isn’t a standard observable like you’ve seen so far, rather, it’s aSubject
, an object that’s a turbocharged observable. For the purposes of this section,stockStream$
acts just like a regular observable. In Multiplexing Observables, you’ll learn about the other neat tricks subjects have up their sleeves.
Reducing streams using scan
So the graph of stock values can render the stock’s value changes over time; next, we need to record the last ten values this observable emitted. When a stream wants to accumulate values, you will turn to reduce
or scan
.
In this case, we want to use scan
, because it emits a new value for every event on the stream, whereas reduce
waits for the stream to complete. This stream never ends, so we use scan
.
We can also use
scan
to accumulate a limited number of values by adding a check for the total length of the array. You need to adjust the data from time-based buckets into stock-based buckets with an extramap
.
Get hands-on with 1300+ tech skills courses.