ExtendableMessageEvent.source
The source
read-only property of the
ExtendableMessageEvent
interface returns a reference to the
Client
object from which the message was sent.
Value
A Client
, ServiceWorker
or MessagePort
object.
Examples
When the following code is used inside a service worker to respond to a push messages
by sending the data received via PushMessageData
to the main context via
a channel message, the event
object of onmessage
will be a ExtendableMessageEvent
.
var port;
self.addEventListener('push', function(e) {
var obj = e.data.json();
if(obj.action === 'subscribe' || obj.action === 'unsubscribe') {
port.postMessage(obj);
} else if(obj.action === 'init' || obj.action === 'chatMsg') {
port.postMessage(obj);
}
});
self.onmessage = function(e) {
console.log(e.source);
port = e.ports[0];
}
Specifications
Specification |
---|
Service Workers 1 # extendablemessage-event-source |
Browser compatibility
BCD tables only load in the browser