浏览器通知

if (window.Notification) {
    var button = document.getElementById('button'), text = document.getElementById('text');
    
    var popNotice = function() {
        if (Notification.permission == "granted") {
            var notification = new Notification("Hi,帅哥:", {
                body: '能够加你为好友吗?',
                icon: 'http://image.zhangxinxu.com/image/study/s/s128/mm1.jpg'
            });
            
            notification.onclick = function() {
                text.innerHTML = '张小姐已于' + new Date().toTimeString().split(' ')[0] + '加你为好友!';
                notification.close();    
            };
        }    
    };
    
    button.onclick = function() {
        if (Notification.permission == "granted") {
            popNotice();
        } else if (Notification.permission != "denied") {
            Notification.requestPermission(function (permission) {
              popNotice();
            });
        }
    };
} else {
    alert('浏览器不支持Notification');    
}

使用简单,易懂。css

如下是apiapi

属性名 释义
dir 默认值是auto, 能够是ltrrtl,有点相似direction属性。表示提示主体内容的水平书写顺序。
lang 提示的语言。没看出来有什么用。你们能够忽略之~
body 提示主体内容。字符串。会在标题的下面显示。比方说上面的“好啊!(害羞.gif)”。
tag 字符串。标记当前通知的标签。
icon 字符串。通知面板左侧那个图标地址。
data 任意类型和通知相关联的数据。
vibrate 通知显示时候,设备震动硬件须要的振动模式。所谓振动模式,指的是一个描述交替时间的数组,分别表示振动和不振动的毫秒数,一直交替下去。例如[200, 100, 200]表示设备振动200毫秒,而后中止100毫秒,再振动200毫秒。
renotify 布尔值。新通知出现的时候是否替换以前的。若是设为true,则表示替换,表示当前标记的通知只会出现一个。注意都这里“当前标记”没?没错,true参数要想其做用,必须tag须要设置属性值。而后,通知就会像这样覆盖:

 

女神弹框覆盖gif

而不会是默认的叠高楼:数组

叠高楼

silent 布尔值。通知出现的时候,是否要有声音。默认false, 表示无声。
sound 字符串。音频地址。表示通知出现要播放的声音资源。
noscreen 布尔值。是否再也不屏幕上显示通知信息。默认false, 表示要在屏幕上显示通知内容。

显示桌面通知

sticky 布尔值。是否通知具备粘性,这样用户不太容易清除通知。默认false, 表示没有粘性。根据我本身的猜想,应该和positionsticky属性值相似。

4. Notification.close()
通知显示了,如何关闭呢?能够经过调用Notification.close()实例方法,实际上,通知若是你放着无论,一段时间后就会自动隐藏,具体多久不详,我估摸着5秒有的。浏览器

5. 事件句柄
Notification.onclick
点击通知,而后……app

Notification.onerror
通知显示异常,而后。例如,明明Notification.permissiondefault,你还让我显示。iphone

下面这些呢有必要独立出来,虽然如今是支持挺好的,可是,因为目前规范并无把它们列入其中,因此,将来有可能浏览器就不支持了。
Notification.onclose
通知关闭了,而后…… 不管是用户手动关闭,仍是直接Notification.close()关闭都会触发该该事件。wordpress

Notification.onshow
通知显示的时候,该干吗干吗~~spa

6. 其余属性值
除了Notification.permission外,Notification还有不少其余只读属性值,可是,基本上和上面的options参数一致,返回的值也是options和默认值的合并值(若是浏览器支持的话)。3d

Notification.title[只读]code

Notification.dir[只读]

Notification.lang[只读]

Notification.body[只读]

Notification.tag[只读]

Notification.icon[只读]

Notification.data[只读]

Notification.silent[只读]

Notification.title[只读]

Notification.timestamp[只读]
通知建立或者可使用的时间。

Notification.noscreen[只读]

Notification.renotify[只读]

Notification.sound[只读]

Notification.sticky[只读]

Notification.vibrate[只读]

相关文章
相关标签/搜索