ExtendableMessageEvent
The ExtendableMessageEvent interface of the Service Worker API represents the event object of a message event fired on a service worker (when a message is received on the ServiceWorkerGlobalScope from another context) — extends the lifetime of such events.
This interface inherits from the ExtendableEvent interface.
Constructor
ExtendableMessageEvent()-
Creates a new
ExtendableMessageEventobject instance.
Properties
Inherits properties from its parent, ExtendableEvent.
-
ExtendableMessageEvent.dataRead only -
Returns the event's data. It can be any data type.
-
ExtendableMessageEvent.originRead only -
Returns the origin of the
Clientthat sent the message. -
ExtendableMessageEvent.lastEventIdRead only -
Represents, in server-sent events, the last event ID of the event source. This is an empty string.
-
ExtendableMessageEvent.sourceRead only -
Returns a reference to the
Clientobject that sent the message. -
ExtendableMessageEvent.portsRead only -
Returns the array containing the
MessagePortobjects representing the ports of the associated message channel.
Methods
Inherits methods from its parent, ExtendableEvent.
Examples
In the below example a page gets a handle to the ServiceWorker object via ServiceWorkerRegistration.active, and then calls its postMessage() function.
// in the page being controlled if (navigator.serviceWorker) { navigator.serviceWorker.register('service-worker.js'); navigator.serviceWorker.addEventListener('message', event => { // event is a MessageEvent object console.log(`The service worker sent me a message: ${event.data}`); }); navigator.serviceWorker.ready.then( registration => { registration.active.postMessage("Hi service worker"); }); }
The service worker can receive the message by listening to the message event:
// in the service worker addEventListener('message', event => { // event is an ExtendableMessageEvent object console.log(`The client sent me a message: ${event.data}`); event.source.postMessage("Hi client"); });
Specifications
| Specification |
|---|
| Service Workers 1 # extendablemessageevent-interface |
Browser compatibility
| Desktop | Mobile | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Chrome | Edge | Firefox | Internet Explorer | Opera | Safari | WebView Android | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | |
ExtendableMessageEvent |
51 |
17 |
45
Extended Support Releases (ESR) before Firefox 78 ESR do not support service workers and the Push API.
|
No |
38 |
11.1 |
51 |
51 |
45 |
41 |
11.3 |
5.0 |
ExtendableMessageEvent |
51 |
17 |
45
Extended Support Releases (ESR) before Firefox 78 ESR do not support service workers and the Push API.
|
No |
38 |
11.1 |
51 |
51 |
45 |
41 |
11.3 |
5.0 |
data |
51 |
17 |
45
Extended Support Releases (ESR) before Firefox 78 ESR do not support service workers and the Push API.
|
No |
38 |
11.1 |
51 |
51 |
45 |
41 |
11.3 |
5.0 |
lastEventId |
51 |
17 |
45
Extended Support Releases (ESR) before Firefox 78 ESR do not support service workers and the Push API.
|
No |
38 |
11.1 |
51 |
51 |
45 |
41 |
11.3 |
5.0 |
origin |
51 |
17 |
No |
No |
38 |
11.1 |
51 |
51 |
No |
41 |
11.3 |
5.0 |
ports |
51 |
17 |
45
Extended Support Releases (ESR) before Firefox 78 ESR do not support service workers and the Push API.
|
No |
38 |
11.1 |
51 |
51 |
45 |
41 |
11.3 |
5.0 |
source |
51 |
17 |
45
Extended Support Releases (ESR) before Firefox 78 ESR do not support service workers and the Push API.
|
No |
38 |
11.1 |
51 |
51 |
45 |
41 |
11.3 |
5.0 |
See also
© 2005–2021 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/API/ExtendableMessageEvent