HTML5桌面通知:notification api

1. 为什么需要HTML5的桌面通知

传统的桌面通知可以写一个div放到页面右下角自动弹出来,并通过轮询等等其他方式去获取消息并推送给用户。这种方式有个弊端就是:当我在使用京东 进行购物的时候,我是不知道人人网有消息推送过来给我的,而必须要等我把当前页面切到人人网才知道有消息推送了。这种方式的消息推送它是基于页面存活的, 但是我们需要这么一种策略:无论你在看哪个页面,只要有消息都应该能推送给我看到,这就是webkitNotification要解决的问题。 Notification生成的消息不依附于某个页面,仅仅依附于浏览器。


2. 一个桌面通知生成的正常流程

我们先来看看一个桌面通知是如何生成的:

  1. 检查浏览器是否支持Notification
  2. 检查浏览器的通知权限(是否允许通知)
  3. 若权限不够则获取浏览器的通知权限
  4. 创建消息通知
  5. 展示消息通知
    NOTE: 关于第一点的说明需要做一些说明,Notification目前还没有标准化,所以目前只支持chrome19+和safari6+;网上有资料显示Firefox26+也支持,但是我拿我的Firefox27检测的结果是无法支持。

3. notification api基础说明及代码示例

目前notification的实现有两种:一种是之前草案中的形式:webkitNotifications对象, 另一种就是未来标准化的形式:Notification对象。首先来说一下webkitNotifications所包含的内容:


3.1 webkitNotifications:

3.1.1. 静态方法


1

2

3

4

5

6

window.webkitNotifications.checkPermission()

//该方法返回0, 1, 2三个值,0代表PERMISSION_ALLOWED,即’允许’;1代表PERMISSION_NOT_ALLOWED,即不允许;2代表PERMISSION_DENIED,即拒绝

window.webkitNotifications.requestPermission()

//调用该方法将会在浏览器的信息栏弹出一个是否允许桌面通知的提醒,该方法只能由用户主动事件触发,如click 或 mouse over,也就是说你不能在document.ready里面直接调用该方法。

window.webkitNotifications.createNotification(‘icon-url‘,‘title‘, ‘body‘ )

//调用该方法将返回一个实例化的webkitNotifications对象

PS:调用以上方法都会存在安全异常,也就是当前页面的permission是否为0。

3.1.2. 实例方法


1

2

3

4

notificationInstance.show()

//调用该方法将在右下角弹出一个通知窗口

notificationInstance.cancel()

//调用该方法将关闭通知窗口

3.2 Notification:

在chrome26+ 终端里面输入window.Notification并键入回车键,会发现这东西它也是存在的,根据某些博客的说法,这个Notification会是 webkitNotifications的标准化形态(传说中的进化),这种方式的实现相对于webkitNotifications的实现更简洁,更面 向对象一些。 构造函数:


1

2

3

4

5

6

7

8

9

10

11

Notification(title, options)

//@param {String} title 要显示的通知标题

//@param {Object} options 备选项参数,键值对

//option 结构如下

dictionary NotificationOptions {

  NotificationDirection dir = "auto";

  DOMString lang = "";

  DOMString body;

  DOMString tag;

  DOMString icon;//在实例化的时候会异步的去获取

};


1

2

//新建一个Notification实例,并根据permission为‘granted‘来完成notification的显示

var notification = new Notification(‘Hello Notification‘,{body:"I‘m an enginneer!"});

3.2.1. 属性

静态属性:

Notification.Permission:

‘default‘ 等同于拒绝 ‘denied‘ 意味着用户不想要通知 ‘granted‘ 意味着用户同意启用通知

Test:在chrome的地址栏里面输入http://www.baidu.com, 打开console,并在里面输入Notification.Permission 默认返回的是‘default‘.

Notes:该属性是只读的不能手动修改


1

2

3

//在百度的首页打开console

Notification.Permission = ‘granted‘

Notification.Permission   //‘default‘


实例属性:

以下属性都需要在Notification实例上才能访问,为只读属性,并且就是通过option来赋值


1

2

3

4

5

Notification.dir    //

Notification.lang

Notification.Body   //通知的具体内容

Notification.tag    //实例化的notification的id

Notification.icon   //通知的缩略图

3.2.2 方法


静态方法

Notification.requestPermission() ``` //该方法将会询问用户是否允许显示通知 ``` 该方法不能由页面自主调用,必须由用户主动事件触发,还是以百度的页面为例,百度的搜索框的id为‘kw‘:


1

2

3

//不通过事件触发直接调用

Notification.requestPermission()

//页面无反应

```Javascript //通过用户主动事件触发来调用 document.getElementById(‘kw‘).onclick=function(){ Notification.requestPermission(); }; //页面信息栏会弹出询问用户是否允许显示桌面通知

```

Notes:当用户同意之后,再次调用该方法则无效,即该方法仅对Notification.Permission不为‘granted‘的时候起作用


实例方法

1

Notification.close()    //该方法允许通过代码控制关掉notification

Notes: Notification 没有实例方法show(),在Notification实例化的时候,浏览器就已经自动的去处理notification的显示过程了。

3.3 代码示例

以下代码将展示如何使用webkitNotification和Notification来显示桌面通知

3.3.1 webkitNotification


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

document.getElementById(‘notifyButton‘).onclick = function(){

    //判断浏览器是否支持notification

    if(window.webkitNotifications){

        //判断当前页面是否被允许发出通知

        if(webkitNotifications.checkPermission==0){

            var icon_url = http://www.w3.org/;

            var title = ‘Hello HTML5‘;

            var body = ‘I will be always here waiting for you!‘;

            var WebkitNotification = webkitNotifications.createNotification(icon_url, title, body);

            WebkitNotification.show();

        }else{

            document.getElementById(‘requestbutton‘).onclick = function () {

                webkitNotifications.requestPermission();

            };

        }

    }else alert("您的浏览器不支持桌面通知特性,请下载谷歌浏览器试用该功能");

};

3.3.2 Notification


1

2

3

4

5

6

7

8

9

10

11

document.getElementById(‘notifyButton‘).onclick = function () {

    if (window.Notification){

        if(Notification.Permission===‘granted‘){

            var notification = new Notification(‘Hello Notification‘,{body:"I hope that all the browser will support this\                   function!"});

        }else {

            document.getElementById(‘requestButton‘).onclick = function (){

                Notification.requestPermission();

            };

        };

    }else alert(‘你的浏览器不支持此特性,请下载谷歌浏览器试用该功能‘);

};

4. 参考文档

LINKS

时间: 2024-10-24 19:21:57

HTML5桌面通知:notification api的相关文章

h5桌面通知Notification

H5中的桌面通知Notification 前言: 对于一个前段开发者,逛网页总会留意一些新奇的功能,对于上班总会用到Teambition的我,总是能收到Notification...所以今天就来研究下这个H5功能... 1. 实例一个Notification let n = new Notification( "这是一个通知消息", //这是必选Title 一定会显示的通知标题 { icon: "xxx.png", // 这个icon是用来显示通知中的左边图片 bo

Chrome浏览器扩展开发系列之十:桌面通知Notification

Desktop Notification也称为Web Notification,是在Web页面之外,以弹出桌面对话框的形式通知用户发生了某事件.Web Notification于2015.9.10成为W3C推荐标准,网址https://www.w3.org/TR/notifications/.每个通知对话框都包括title, direction, language和origin.通知对话框还可以有body, tag, icon URL和icon image. 通知必须获得用户的授权才能够显示,从

html5桌面通知,notification的使用

1先判断浏览器是否支持:window.Notification 2判断浏览器是否开启提示的权限:Notification.permission === 'granted'(如果不允许则设置为允许:Notification.requestPermission()) 3设置提示的内容:var notification = new Notification('订单提示', { body: "您有新订单:" + data + "" });//Notification(&qu

[html5] (Notification) 桌面通知

前几天要做一个桌面通知的功能,翻查以前做的笔记,发现webkitNotifications这个已经不能用了,baidu了下,基本都是介绍webkitNotifications的,后来在SOF上找到答案,现在chrome支持的是Notification,估计是W3C标准化了.api也变了,mark之. Notification Properties title:"别动神仙说:" body:"这里是body" icon:"http://q4.qlogo.cn/

【Html5】Html5新特性Notification实现桌面消息推送(2016-05-25)

序:最近工作使用WorkTile,发现使用Chrome浏览器的时候如果有任务下发给我则会在桌面右下角提示(当前浏览器为最小化模式).感觉这个东西蛮有意思的,感觉可以给用户更好的体验,于是乎就查询了一下,发现是Html5的新特性. 0x01:IE内核的浏览器还不可以,但在Chrome与Firefox上已经实现了此API. 0x02:代码简单直接看吧 1 <!DOCTYPE html> 2 3 <html xmlns="http://www.w3.org/1999/xhtml&qu

HTML5实战之桌面通知

桌面通知功能能够让浏览器即使是最小化状态也能将消息通知给用户.这和WebIM是最为天然的结合.不过,目前支持Desktop Notification功能的浏览器只有Chrome5+. 关于通知的基础知识可以参考以下文档: W3C标准:http://dev.w3.org/2006/webapi/WebNotifications/publish/Notifications.html 使用教程:http://www.html5rocks.com/en/tutorials/notifications/q

chrome浏览器的桌面通知

最近在使用朋友网(不加链接,避免有打广告的嫌疑),发现会出现提示“是否允许网站显示桌面通知?”,如下图所示: 这种做法,在页面加载完时直接调用请求,比起开心网的这种提示感觉有些野蛮了.开心网的桌面通知提示如下: 先检查用户是否已经允许了本站的桌面通知,在未允许的情况下:点击后Chrome才出现提示,感觉更人性化一些,起码这个通知出现是由用户主动触发的. 这两个网站,发现桌面通知主要用于webIM的消息提醒.查了下资料,大概了解和掌握了Chrome桌面通知的.做了如下图所示的一个Demo: 完整的

通知 Notification 详解

效果 通知栏-刚收到通知时 通知栏-收到通知几秒后 标准视图 大视图-下滑前是标准视图 大视图-下滑后显示大视图 自定义通知 讲解 Notification,俗称通知,是一种具有全局效果的通知,它展示在屏幕的顶端,首先会表现为一个图标的形式,当用户向下滑动的时候,展示出通知具体的内容. 注意:因为一些Android版本的兼容性问题,对于Notification而言,Android3.0是一个分水岭,在其之前构建Notification推荐使用Notification.Builder构建,而在An

兼容 谷歌、火狐、360系列浏览器桌面通知()有用

兼容 谷歌.火狐.360系列浏览器桌面通知(有用) 本文从总结工作,并且参照大量的网络资源的.我们希望有同样需求的朋友来帮忙. (部分): http://xsk.tehon.org/den/index.php/category/tech/html5-audio-notifications.html http://ttsvetko.github.io/HTML5-Desktop-Notifications/# http://www.cnblogs.com/meteoric_cry/archive/