Did you know: you can modify the URL as you see fit 🙃

Having a server push data to the client is one of the coolest things you can do for your web application. I'm sure we've all came across this issue before: when writing a chat app, you do something like (() => setInterval(getMessages, 1000))(). The problem is, you only get new messages every 1000ms. No matter what interval you choose, it's either going to be too long or too short. This is what "polling" is - the client periodically pings the server for new data.

Today, pushing data can be accomplished using WebSockets. Your client can listen for updates simply by adding an event listener: new WebSocket('ws://host:8080').addEventListener('message', ...);. Many people use Express with a NodeJS backend for their WebSocket adventures. This is fairly easy to setup since all you need is some VPS somewhere. However, hosting is not free. I've used Vultr before and it's quite nice, but it's still a monthly expense on top of the shared Apache hosting I currently buy. How can we achieve push without shiny new tech like NodeJS and Express? Enter long polling.

read on »

November 26, 2017 | 1 comment
© 2019 Michael Cheng
made in Taiwan