--- title: ExtendableMessageEvent.data slug: Web/API/ExtendableMessageEvent/data tags: - API - ExtendableMessageEvent - Property - Reference - Service Workers - data translation_of: Web/API/ExtendableMessageEvent/data ---

{{APIRef("Service Workers API")}}

{{domxref("ExtendableMessageEvent")}} インターフェイスの data 読み取り専用プロパティは、イベントのデータを返します。 任意のデータ型を使用できます。

構文

var myData = extendableMessageEvent.data;

任意のデータ型。

次のコードをサービスワーカー内で使用して、{{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) {
  console.log(e.data);
  port = e.ports[0];
}

仕様

仕様 状態 コメント
{{SpecName('Service Workers', '#dom-extendablemessageevent-data', 'ExtendableMessageEvent.data')}} {{Spec2('Service Workers')}} 初期定義

ブラウザーの互換性

{{Compat("api.ExtendableMessageEvent.data")}}

関連情報