Web/Desktop Notification API - 在刷新页面时强制关闭所有通知

Posted

技术标签:

【中文标题】Web/Desktop Notification API - 在刷新页面时强制关闭所有通知【英文标题】:Web/Desktop Notification API - force close all notifications upon refreshing the page 【发布时间】:2015-06-04 12:07:38 【问题描述】:

我一直在研究 Web 通知 API 或桌面通知 API。我了解它的构造方式以及它支持的属性和事件的数量。通知旨在与浏览器分开,以便即使浏览器最小化,例如,通知仍然可以显示。

我的问题是,有没有办法将通知与网页上的操作联系起来?特别是,我想在刷新页面时关闭所有通知对话框。我怎样才能做到这一点?

提前致谢。

【问题讨论】:

【参考方案1】:

你没有提到服务工作者,但我假设你有一个,因为你需要它来实现推送和通知 API。

当页面加载时,您可以向服务人员发送一条消息,指示其关闭所有通知。然后,您可以像这样在工作人员中执行此操作:

self.getNotifications().then(function(notifications)
  notifications.forEach(function(notification)
    notification.close()
  )
)

但是,您可以跳过向服务工作人员发送消息,只需通过服务工作人员注册从页面执行此操作,如下所示:

navigator.serviceWorker.getRegistration().then(function(registration)
  registration.getNotifications().then(function(notifications)
    notifications.forEach(function(notification)
      notification.close()
    )
  )
)

但是,请注意 getNotifications() 仅适用于 Chrome 44。在 Chrome 44 之前,或在其他浏览器中,我不相信有办法做你想做的事。

【讨论】:

以上是关于Web/Desktop Notification API - 在刷新页面时强制关闭所有通知的主要内容,如果未能解决你的问题,请参考以下文章

navigator.notification.* 失败“navigator.notification [undefined] 不是对象”

Notification通知栏

Notification通知栏

Notification(Notification的通知栏常驻各种样式点击无效禁止滑动删除兼容低版本)

求教notification问题

Notification