web-worker
Native cross-platform Web Workers. Works in published npm modules.
import Worker from 'web-worker';
const worker = new Worker('data:,postMessage("hello")');
worker.onmessage = e => console.log(e.data); // "hello"
In Node, it's a web-compatible Worker implementation atop Node's worker_threads.
In the browser (and when bundled for the browser), it's simply an alias of Worker.
Features
Here's how this is different from worker_threads:
- makes Worker code compatible across browser and Node
- uses DOM-style events (Event.data, Event.type, etc)
- supports event handler properties (
worker.onmessage=..) Worker()constructor accepts a module URL- Supports the
{ type: 'module' }option natively in Node 12.8+ - emulates browser-style WorkerGlobalScope within the worker
Usage Example
| main.js | worker.js |
|---|---|
|
|
Module Workers
Module Workers are supported in Node 12.8+ using this plugin, leveraging Node's native ES Modules support. In the browser, they can be used natively in Chrome 80+, or in all browsers via worker-plugin or rollup-plugin-off-main-thread. As with classic workers, there is no difference in usage between Node and the browser:
| main.mjs | worker.mjs |
|---|---|
|
|
Data URLs
Instantiating Worker using a Data URL is supported in both module and classic workers:
import Worker from 'web-worker';
const worker = new Worker(`data:application/javascript,postMessage(42)`);
worker.addEventListener('message', e => {
console.log(e.data) // 42
});
Special Thanks
This module aims to provide a simple and forgettable piece of infrastructure,
and as such it needed an obvious and descriptive name.
@calvinmetcalf, who you may recognize as the author of Lie and other fine modules, gratiously offered up the name from his web-worker package.
Thanks Calvin!