--- title: Web Workers API slug: Web/API/Web_Workers_API tags: - API - NeedsTranslation - Service Workers - Shared Workers - TopicStub - Web Workers - Workers translation_of: Web/API/Web_Workers_API ---
{{DefaultAPISidebar("Web Workers API")}}
Web Workers makes it possible to run a script operation in background thread separate from the main execution thread of a web application. The advantage of this is that laborious processing can be performed in a separate thread, allowing the main (usually the UI) thread to run without being blocked/slowed down.
A worker is an object created using a constructor (e.g. {{domxref("Worker.Worker", "Worker()")}}) that runs a named JavaScript file — this file contains the code that will run in the worker thread; workers run in another global context that is different from the current {{domxref("window")}}. This context is represented by a {{domxref("DedicatedWorkerGlobalScope")}} object in the case of dedicated workers (standard workers that are utilized by a single script; shared workers use {{domxref("SharedWorkerGlobalScope")}}).
You can run whatever code you like inside the worker thread, with some exceptions. For example, you can't directly manipulate the DOM from inside a worker, or use some default methods and properties of the {{domxref("window")}} object. But you can use a large number of items available under window
, including WebSockets, and data storage mechanisms like IndexedDB and the Firefox OS-only Data Store API. See Functions and classes available to workers for more details.
Data is sent between workers and the main thread via a system of messages — both sides send their messages using the postMessage()
method, and respond to messages via the onmessage
event handler (the message is contained within the {{event("Message")}} event's data
property). The data is copied rather than shared.
Workers may in turn spawn new workers, as long as those workers are hosted within the same origin as the parent page. In addition, workers may use XMLHttpRequest
for network I/O, with the exception that the responseXML
and channel
attributes on XMLHttpRequest
always return null
.
In addition to dedicated workers, there are other types of worker:
Note: As per the Web workers Spec, worker error events should not bubble (see {{bug(1188141)}}. This has been implemented in Firefox 42.
Worker
.We have created a couple of simple demos to show basic usage:
You can find out more information on how these demos work in Using web workers.
Specification | Status | Comment |
---|---|---|
{{SpecName('HTML WHATWG', '#workers')}} | {{Spec2('HTML WHATWG')}} |
Feature | Chrome | Edge | Firefox (Gecko) | Internet Explorer | Opera | Safari (WebKit) |
---|---|---|---|---|---|---|
Basic support | 4 | {{CompatVersionUnknown}} | {{CompatGeckoDesktop(1.9.1)}} | 10.0 | 10.6 | 4 |
Shared workers | 4 | {{CompatNo}} | {{CompatGeckoDesktop(29)}} | {{CompatNo}} | 10.6 | 4 |
Passing data using structured cloning | 13 | {{CompatVersionUnknown}} | {{CompatGeckoDesktop(8)}} | 10.0 | 11.5 | 6 |
Passing data using transferable objects | 17 {{property_prefix("webkit")}} 21 |
{{CompatNo}} | {{CompatGeckoDesktop(18)}} | {{CompatNo}} | 15 | 6 |
Global {{domxref("window.URL", "URL")}} | 10[1] 23 |
{{CompatVersionUnknown}} | {{CompatGeckoDesktop(21)}} | 11 | 15 | 6[1] |
Feature | Android | Chrome for Android | Edge | Firefox Mobile (Gecko) | Firefox OS (Gecko) | IE Phone | Opera Mobile | Safari Mobile |
---|---|---|---|---|---|---|---|---|
Basic support | 4.4 | 4 | {{CompatVersionUnknown}} | {{CompatGeckoMobile(1.9.1)}} | 1.0.1 | 10.0 | 11.5 | 5.1 |
Shared workers | {{CompatNo}} | 4 | {{CompatNo}} | 29 | 1.4 | {{CompatNo}} | {{CompatNo}} | {{CompatNo}} |
Passing data using structured cloning | {{CompatNo}} | 4 | {{CompatVersionUnknown}} | 8 | 1.0.1 | {{CompatNo}} | {{CompatNo}} | {{CompatNo}} |
Passing data using transferable objects | {{CompatNo}} | {{CompatNo}} | {{CompatNo}} | 18 | 1.0.1 | {{CompatNo}} | {{CompatNo}} | {{CompatNo}} |
[1] As webkitURL
.