Back to Content

ServiceWorkerGlobalScope: message event

files/en-us/web/api/serviceworkerglobalscope/message_event/index.md

latest3.4 KB
Original Source

{{APIRef("Service Workers API")}}{{SecureContext_Header}}{{AvailableInWorkers("service")}}

The message event of the {{domxref("ServiceWorkerGlobalScope")}} interface occurs when incoming messages are received. Controlled pages can use the {{domxref("ServiceWorker.postMessage()")}} method to send messages to service workers. The service worker can optionally send a response back via the {{domxref("Client.postMessage()")}}, corresponding to the controlled page.

This event is not cancelable and does not bubble.

Syntax

Use the event name in methods like {{domxref("EventTarget.addEventListener", "addEventListener()")}}, or set an event handler property.

js-nolint
addEventListener("message", (event) => { })

onmessage = (event) => { }

Event type

An {{domxref("ExtendableMessageEvent")}}. Inherits from {{domxref("ExtendableEvent")}}.

{{InheritanceDiagram("ExtendableMessageEvent")}}

Event properties

Inherits properties from its parent, {{domxref("ExtendableEvent")}}.

  • {{domxref("ExtendableMessageEvent.data")}} {{ReadOnlyInline}}
    • : Returns the event's data. It can be any data type. If dispatched in messageerror event, the property will be null.
  • {{domxref("ExtendableMessageEvent.origin")}} {{ReadOnlyInline}}
    • : Returns the origin of the {{domxref("Client")}} that sent the message.
  • {{domxref("ExtendableMessageEvent.lastEventId")}} {{ReadOnlyInline}}
  • {{domxref("ExtendableMessageEvent.source")}} {{ReadOnlyInline}}
    • : Returns a reference to the {{domxref("Client")}} object that sent the message.
  • {{domxref("ExtendableMessageEvent.ports")}} {{ReadOnlyInline}}
    • : Returns the array containing the {{domxref("MessagePort")}} objects representing the ports of the associated message channel.

Examples

In the below example a page gets a handle to the {{domxref("ServiceWorker")}} object via {{domxref("ServiceWorkerRegistration.active")}}, and then calls its postMessage() function.

js
// main.js
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:

js
// service-worker.js
addEventListener("message", (event) => {
  // event is an ExtendableMessageEvent object
  console.log(`The client sent me a message: ${event.data}`);

  event.source.postMessage("Hi client");
});

Alternatively, the script can listen for the message using onmessage:

js
// service-worker.js
self.onmessage = (event) => {
  // event is an ExtendableMessageEvent object
  console.log(`The client sent me a message: ${event.data}`);

  event.source.postMessage("Hi client");
};

Specifications

{{Specifications}}

Browser compatibility

{{Compat}}

See also