NotificationEvent.notification

notificationNotificationEvent インターフェイスの読取専用プロパティで、クリックされてイベントを発行した Notification のインスタンスを返します。 Notificationtagdata 属性など、 Notification のインスタンス化時に設定された多くのプロパティへの読み取り専用アクセスを提供しており、あとで notificationclick イベントで使用するための情報を保存することができます。

返値

Notification オブジェクト。

js
self.addEventListener("notificationclick", function (event) {
  console.log("On notification click");

  // Data can be attached to the notification so that you
  // can process it in the notificationclick handler.
  console.log("Notification Tag:", event.notification.tag);
  console.log("Notification Data:", event.notification.data);
  event.notification.close();

  // This looks to see if the current is already open and
  // focuses if it is
  event.waitUntil(
    clients
      .matchAll({
        type: "window",
      })
      .then(function (clientList) {
        for (var i = 0; i < clientList.length; i++) {
          var client = clientList[i];
          if (client.url == "/" && "focus" in client) return client.focus();
        }
        if (clients.openWindow) return clients.openWindow("/");
      }),
  );
});

仕様書

Specification
Notifications API Standard
# ref-for-dom-notificationevent-notification

ブラウザーの互換性

BCD tables only load in the browser