This is an experimental technology
Check the Browser compatibility table carefully before using this in production.
The ServiceWorker
interface of the ServiceWorker API provides a reference to a service worker. Multiple browsing contexts (e.g. pages, workers, etc.) can be associated with the same service worker, each through a unique ServiceWorker
object.
A ServiceWorker
object is available in the ServiceWorkerRegistration.active
property, and the ServiceWorkerContainer.controller
property — this is a service worker that activated and controlling the page (the service worker has been successfully registered, and the controlled page has been reloaded.)
The ServiceWorker
interface is dispatched a set of lifecycle events — install
and activate
— and functional events including fetch
. A ServiceWorker
object has an associated ServiceWorker.state
, related to its lifecycle.
The ServiceWorker
interface inherits properties from its parent, Worker
.
ServiceWorker.scriptURL
Read only
ServiceWorker
serialized script URL defined as part of ServiceWorkerRegistration
. The URL must be on the same origin as the document that registers the ServiceWorker
.ServiceWorker.state
Read only
installing
, installed,
activating
, activated
, or redundant
.ServiceWorker.onstatechange
Read only
EventListener
property called whenever an event of type statechange
is fired; it is basically fired anytime the ServiceWorker.state
changes.The ServiceWorker
interface inherits methods from its parent, Worker
, with the exception of Worker.terminate
— this should not be accessible from service workers.
This code snippet is from the service worker registration-events sample (live demo). The code listens for any change in the ServiceWorker.state
and returns its value.
if ('serviceWorker' in navigator) { navigator.serviceWorker.register('service-worker.js', { scope: './' }).then(function (registration) { var serviceWorker; if (registration.installing) { serviceWorker = registration.installing; document.querySelector('#kind').textContent = 'installing'; } else if (registration.waiting) { serviceWorker = registration.waiting; document.querySelector('#kind').textContent = 'waiting'; } else if (registration.active) { serviceWorker = registration.active; document.querySelector('#kind').textContent = 'active'; } if (serviceWorker) { // logState(serviceWorker.state); serviceWorker.addEventListener('statechange', function (e) { // logState(e.target.state); }); } }).catch (function (error) { // Something went wrong during registration. The service-worker.js file // might be unavailable or contain a syntax error. }); } else { // The current browser doesn't support service workers. }
Specification | Status | Comment |
---|---|---|
Service Workers The definition of 'ServiceWorker' in that specification. | Working Draft | Initial definition. |
Desktop | ||||||
---|---|---|---|---|---|---|
Chrome | Edge | Firefox | Internet Explorer | Opera | Safari | |
Basic support | 40 | 17
|
44
|
No | 27 | 11.1 |
scriptURL
|
40 | 17
|
44
|
No | 27 | 11.1 |
state
|
40 | 17
|
44
|
No | 27 | 11.1 |
onstatechange
|
40 | 17
|
44
|
No | 27 | 11.1 |
Mobile | |||||||
---|---|---|---|---|---|---|---|
Android webview | Chrome for Android | Edge Mobile | Firefox for Android | Opera for Android | iOS Safari | Samsung Internet | |
Basic support | 40 | 40 | ? | 44 | 27 | 11.1 | 4.0 |
scriptURL
|
40 | 40 | ? | 44 | 27 | 11.1 | 4.0 |
state
|
40 | 40 | ? | 44 | 27 | 11.1 | 4.0 |
onstatechange
|
40 | 40 | ? | 44 | 27 | 11.1 | 4.0 |
Promises
© 2005–2018 Mozilla Developer Network and individual contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorker