`

HTML5桌面通知api:Notification

阅读更多

清纯美女图片站打包成android app的时候,需要用到桌面通知 Notification API 现将这个记录下,备用

Notification API 是 HTML5 新增的桌面通知 API,用于向用户显示通知信息。该通知是脱离浏览器的,即使用户没有停留在当前标签页,甚至最小化了浏览器,该通知信息也一样会置顶显示出来。

用户权限

想要向用户显示通知消息,需要获取用户权限,而相同的域名只需要获取一次权限。只有用户允许的权限下,Notification 才能起到作用,避免某些网站的广告滥用 Notification 或其它给用户造成影响。那么如何知道用户到底是允不允许的?

Notification.permission 该属性用于表明当前通知显示的授权状态,可能的值包括:

  • default :不知道用户的选择,默认。
  • granted :用户允许。
  • denied :用户拒绝。
  1. if(Notification.permission === 'granted'){ 
  2.     console.log('用户允许通知'); 
  3. }else if(Notification.permission === 'denied'){ 
  4.     console.log('用户拒绝通知'); 
  5. }else
  6.     console.log('用户还没选择,去向用户申请权限吧'); 

请求权限

当用户还没选择的时候,我们需要向用户去请求权限。Notification 对象提供了 requestPermission() 方法请求用户当前来源的权限以显示通知。

以前基于回调的语法已经弃用(当然在现在的浏览器中还是能用的),最新的规范已将此方法更新为基于 promise 的语法:

  1. Notification.requestPermission().then(function(permission) { 
  2.     if(permission === 'granted'){ 
  3.         console.log('用户允许通知'); 
  4.     }else if(permission === 'denied'){ 
  5.         console.log('用户拒绝通知'); 
  6.     } 
  7. }); 

推送通知

获取用户授权之后,就可以推送通知了。

  1. var notification = new Notification(title, options) 

参数如下:

title:通知的标题

options:通知的设置选项(可选)。

  • body:通知的内容。
  • tag:代表通知的一个识别标签,相同tag时只会打开同一个通知窗口。
  • icon:要在通知中显示的图标的URL。
  • image:要在通知中显示的图像的URL。
  • data:想要和通知关联的任务类型的数据。

requireInteraction:通知保持有效不自动关闭,默认为false。

还有一些其他的参数,因为用不了或者没什么用这里就没必要说了。

  1. var n = new Notification('状态更新提醒',{ 
  2.     body: '你的朋友圈有3条新状态,快去查看吧'
  3.     tag: 'linxin'
  4.     icon: 'http://blog.gdfengshuo.com/images/avatar.jpg'
  5.     requireInteraction: true 
  6. }) 

通知消息的效果图如下:

关闭通知

从上面的参数可以看出,并没有一个参数用来配置显示时长的。我想要它 3s 后自动关闭的话,这时可以调用 close() 方法来关闭通知。

  1. var n = new Notification('状态更新提醒',{ 
  2.     body: '你的朋友圈有3条新状态,快去查看吧' 
  3. }) 
  4. setTimeout(function() { 
  5.     n.close(); 
  6. }, 3000); 

事件

Notification 接口的 onclick属性指定一个事件侦听器来接收 click 事件。当点击通知窗口时会触发相应事件,比如打开一个网址,引导用户回到自己的网站去。

  1. var n = new Notification('状态更新提醒',{ 
  2.     body: '你的朋友圈有3条新状态,快去查看吧'
  3.     data: { 
  4.         url: 'http://blog.gdfengshuo.com' 
  5.     } 
  6. }) 
  7. n.onclick = function(){ 
  8.     window.open(n.data.url, '_blank');      // 打开网址 
  9.     n.close();                              // 并且关闭通知 

应用场景

前面说那么多,其实就是为了用。那么到底哪些地方可以用到呢?

现在网站的消息提醒,大多数都是在消息中心显示个消息数量,然后发邮件告诉用户,这流程完全没有错。不过像我这种用户,觉得别人点个赞,收藏一下都要发个邮件提醒我,老是要去删邮件(强迫症),我是觉得挺烦的甚至关闭了邮件提醒。

当然这里并不是说要用 Notification,毕竟它和邮件的功能完全不一样。

我觉得比较适合的是新闻网站。用户浏览新闻时,可以推送给用户实时新闻。以腾讯体育为例,它就使用了 Notification API。在页面中引入了一个 notification2017_v0118.js,有兴趣可以看看别人是怎么成熟的使用的。

一进入页面,就获取授权,同时自己页面有个浮动框提示你允许授权。如果允许之后,就开始给你推送通知了。不过它在关闭标签卡的时候,通知也会被关闭,那是因为监听了页面 beforeunload 事件。

  1. function addOnBeforeUnload(e) { 
  2.     FERD_NavNotice.notification.close(); 
  3. if(window.attachEvent){ 
  4.     window.attachEvent('onbeforeunload', addOnBeforeUnload); 
  5. else { 
  6.     window.addEventListener('beforeunload', addOnBeforeUnload, false); 

兼容

说到兼容,自然是倒下一大片,而且各浏览器的表现也会有点差异。移动端的几乎全倒,PC端的还好大多都能支持,除了IE。所以使用前,需要先检查一下浏览器是否支持 Notification。

分享到:
评论

相关推荐

    HTML5实现Notification API桌面通知功能

    HTML5的桌面通知功能是现代Web应用程序与用户交互的重要方式之一,它使得浏览器能够在后台或用户专注于其他页面时发送提醒。这种通知不依赖于特定的网页,而是由浏览器本身管理,确保用户不会错过任何重要的消息。...

    Notify_html5桌面通知

    综上所述,"Notify_html5桌面通知"是一个利用HTML5 `Notification` API实现的浏览器桌面提醒功能,它提高了Web应用的交互性和用户体验。通过学习和实践,开发者可以将这一特性应用到自己的Web项目中,提供更加丰富的...

    突袭HTML5之Javascript API扩展5—其他扩展(应用缓存/服务端消息/桌面通知)

    在这篇文章中,我们将聚焦于三个关键的API扩展:应用缓存、服务端消息和桌面通知。 首先,让我们详细探讨**应用缓存**。应用缓存是HTML5离线存储的一种方式,允许开发者将静态资源(如HTML、CSS、JavaScript文件等...

    html5桌面通知知识点分享

    HTML5 Web Notification 桌面通知API是HTML5引入的一个重要特性,它解决了传统网页消息交互方式的局限性,如闪烁页面标题等。这一特性使得开发者能够创建类似桌面应用的通知,即使浏览器窗口最小化或被遮挡,用户也...

    前端项目-HTML5Notification.zip

    要在项目中使用这个polyfill,你需要将`notification-polyfill.js`引入到你的HTML页面中,然后按照HTML5通知API的规范编写代码。首先检查权限,根据权限状态决定是否请求或直接创建通知。 6. **注意事项**: - ...

    node webkit桌面通知demo

    Node Webkit 桌面通知 Demo 是一个使用 Node Webkit 框架创建的示例应用,它展示了如何在桌面环境中实现本地通知功能。Node Webkit 是一个强大的工具,它结合了 Node.js 的服务器端 JavaScript 功能和 Chromium ...

    HTML5 Notification(桌面提醒)功能使用实例

    一、HTML5 Notification 简介HTML5 Notification ,即桌面通知。目前浏览器依然是一个严格的沙盒工作模式,这种模式把浏览器和桌面的通信隔离开。Notification可以跨越沙盒能够让浏览器即使是最小化状态也能将消息...

    使用HTML5的Notification API制作web通知的教程

    在本文中,我们将深入探讨如何使用HTML5的Notification API来创建Web通知,这是一种可以在用户桌面或移动设备上显示提醒信息的高效方式。首先,我们需要确保目标浏览器支持这一API。你可以通过访问caniuse.com来检查...

    Html5中的桌面通知Notification的实现

    HTML5中的桌面通知功能是现代Web应用中一种增强用户体验的重要特性。通过`Notification` API,开发者可以在用户浏览器的桌面或移动设备上显示提醒通知,即使用户不在网站或应用的前端界面,也能接收到重要的信息。...

    HTML5实现桌面通知 提示功能

    总的来说,HTML5的桌面通知功能通过`Notification`对象和相关的API,为Web开发者提供了与用户更直接、更即时的沟通方式。正确使用这一特性,可以提升用户体验,但同时也应尊重用户的选择,避免滥用通知打扰用户。

    HTML5制作的桌面提醒

    Notification API是HTML5中的一个重要特性,它允许网页应用向用户发送桌面级别的通知。这些通知可以在用户不浏览页面时出现,类似于操作系统级别的提醒。 - **检查权限**:在发送通知前,需要先检查浏览器是否支持...

    仿windows桌面系统

    在仿Windows桌面系统中,开发者可能利用HTML5的Web通知API(Notification API)来创建类似的功能,允许程序向用户发送视觉提示。 5. **桌面分屏**:Windows系统支持多窗口并排显示,方便用户同时查看和操作多个应用...

    html5桌面提醒功能.zip

    Web Notifications API是HTML5的一部分,它使得开发者可以创建和管理跨平台的桌面通知。通过这个API,开发者可以向用户的操作系统发送定制的通知,这些通知通常包含标题、文本和图标等元素,以吸引用户的注意力。 ...

    Notification.zip

    2. **Notification API**:HTML5提供了`Notification`接口,通过这个API,开发者可以创建、显示和管理桌面通知。例如,创建一个新的通知实例需要调用`new Notification(title, options)`,其中`title`是通知的标题,...

    html5桌面通知(Web Notifications)实例解析

    在HTML5中,桌面通知主要通过Notification接口实现。该接口允许网页直接与用户的桌面通知系统交互。在页面中可以编写JavaScript代码来实现通知功能,包括请求用户授权、创建通知以及设置通知的相关行为。 首先,...

    native-api-notification-[removed]JavaScript中的本机通知API

    :pushpin: Notifications API界面用于在用户桌面上配置和显示通知。 通知的外观和某些特定功能在平台之间有所不同,但通常它们提供了一种向用户提供信息的异步​​方式。 :laptop: 技术领域 该项目是使用以下技术...

    chrome浏览器javascript在windows任务栏上弹出消息通知框.zip

    要调试和测试这类功能,开发者需要确保其使用的Chrome版本支持`Notification` API,并且在隐私设置中启用了桌面通知。在实际应用中,为了兼容其他浏览器,应检查`Notification`对象是否存在,以及用户是否已经授予了...

    HTML5中的Web Notification桌面右下角通知功能的实现

    桌面通知可以跨越浏览器窗口或标签页的限制,即使浏览器被最小化,用户仍能收到通知。在HTML5的众多新特性中,Web Notification是一大亮点,它极大地增强了网站与用户之间的交互性。 要实现Web Notification功能,...

Global site tag (gtag.js) - Google Analytics