data:image/s3,"s3://crabby-images/674d0/674d0efd4d1cae7b927bfa9569b07f8660a878a4" alt="cover"
If we want to update a part of the data on the webpage in real time, what should we generally do? Obviously, it's server-side push, and the specific implementation technologies can be Websocket, Polling, SSE...
However, I once saw an article like this on HackerNews:
data:image/s3,"s3://crabby-images/f5220/f522055be3eeeda63b18ddf53198463868de0c23" alt=""
The author inserted an image on the webpage, which can display the current number of online users in real-time without refreshing the page. At first glance, it really feels quite magical!
data:image/s3,"s3://crabby-images/1f5c6/1f5c652d4d4a6bc88e5755ea57a970e43323f38f" alt=""
This type of image is called MJPEG, which is essentially a JPEG animation in some sense. The browser itself also supports it. The principle is that in a single request, the server marks the Response Content-Type as multipart/X-Mixed-Replace and continuously sends a complete JPEG. Once the browser receives a new image, it refreshes the image, thus forming a video stream.
In this way, the principle is actually the same as the Server Side Event I shared before, except that SSE is constantly issuing text, while multipart/X-Mixed-Replace is issuing binary.
Following this idea, I implemented a server-side rendering service for Game of Life. No matter how many browser pages are launched, all pages will always see the same frame of the image!