ExtendableMessageEvent.ports
ports
は ExtendableMessageEvent
インターフェイスの読み取り専用プロパティで、関連するメッセージチャンネル(メッセージが送信されるチャンネル)のポートを表す MessagePort
オブジェクトを含む配列を返します。
値
MessagePort
オブジェクトの配列。
例
次のコードをサービスワーカー内で使用して、PushMessageData
を介して受信したデータをチャンネルメッセージを介してメインコンテキストに送信することにより、プッシュメッセージに応答する場合、onmessage
のイベントオブジェクトは ExtendableMessageEvent
になります。
let port;
self.addEventListener('push', (e) => {
const 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 = (e) => {
port = e.ports[0];
}
仕様書
Specification |
---|
Service Workers # extendablemessage-event-ports |
ブラウザーの互換性
BCD tables only load in the browser