--- title: ExtendableMessageEvent.ports slug: Web/API/ExtendableMessageEvent/ports tags: - API - ExtendableMessageEvent - Property - Reference - Service Workers - ports translation_of: Web/API/ExtendableMessageEvent/ports ---
{{APIRef("Service Workers API")}}
{{domxref("ExtendableMessageEvent")}} インターフェイスの ports
読み取り専用プロパティは、関連するメッセージチャンネル(メッセージが送信されるチャンネル)のポートを表す {{domxref("MessagePort")}} オブジェクトを含む配列を返します。
var myPorts = extendableMessageEvent.ports;
{{domxref("MessagePort")}} オブジェクトの配列。
次のコードをサービスワーカー内で使用して、{{domxref("PushMessageData")}} を介して受信したデータをチャンネルメッセージを介してメインコンテキストに送信することにより、プッシュメッセージに応答する場合、onmessage
のイベントオブジェクトは 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) { port = e.ports[0]; }
仕様 | 状態 | コメント |
---|---|---|
{{SpecName('Service Workers', '#dom-extendablemessageevent-ports', 'ExtendableMessageEvent.ports')}} | {{Spec2('Service Workers')}} | 初期定義 |
{{Compat("api.ExtendableMessageEvent.ports")}}