ExtendableMessageEvent.ports

Baseline Widely available

This feature is well established and works across many devices and browser versions. It’s been available across browsers since April 2018.

portsExtendableMessageEvent インターフェイスの読み取り専用プロパティで、関連するメッセージチャンネル(メッセージが送信されるチャンネル)のポートを表す MessagePort オブジェクトを含む配列を返します。

MessagePort オブジェクトの配列。

次のコードをサービスワーカー内で使用して、PushMessageData を介して受信したデータをチャンネルメッセージを介してメインコンテキストに送信することにより、プッシュメッセージに応答する場合、onmessage のイベントオブジェクトは ExtendableMessageEvent になります。

js
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

関連情報