/pika-worker

A demo to illustrate a web workers advantages (mainly keeping UI interactive when executing heavy tasks/logic).

Primary LanguageCSSApache License 2.0Apache-2.0

Logo

PikaWorker

issues license

A demo to illustrate a web workers advantage (using Pikachu running as an example).


What is this?

This repo demos the advantages of using a web worker to solve the UI being clogged up, this results in a better overall experience as it keeps our apps interative whilst performing heavy computations.


Demo of Web Worker Pickachu Example
(Example taken from the codepen example, found here)


An explanation.

A way to solve "jank" on the web is to stop intensive tasks/calculations running on the main thread and instead run operations adjacent to the main thread. This results in the main thread being freed; it can now perform UI operations which result in the app remaining interactive.

// index.js
if(window.Worker) {
	const myCoolWorker = new Worker('worker.js')
	myCoolWorker.onMessage = e => console.log(`Message ${e.data}`)
	myCoolWorker.postMessage(id)
}

To create a worker all we do is instantiate a new worker and point it to a worker file. Next, we set an onmessage handler which acts as our communications channel for it to chat to us. Lastly, we send a postMessage to kick off the worker (we also send it some data, in this case an id).

// worker.js
onmessage = async function(e) {
	const id = e.data
	const response = await fetch(`/do/cool/stuff/${id}`)
	const data = await response.json()
	self.postMessage(data);
}

In the worker itself we have an onmessage handler in which we are receiving the passed id and we're doing a some arbitrary logic (in this case a fetch) and then passing the result back up.

The worker is useful as here we can offload a ton of logic (e.g. transformations that are computationally heavy). Doing this won't "jank" out our UIs and allows everything to remain interactive.


Pretty Cool! 🤙