浏览器通知
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'); }
使用简单,易懂。
以下是api
属性名 | 释义 |
---|---|
dir | 默认值是auto , 可以是ltr 或rtl ,有点类似direction属性。表示提示主体内容的水平书写顺序。 |
lang | 提示的语言。没看出来有什么用。大家可以忽略之~ |
body | 提示主体内容。字符串。会在标题的下面显示。比方说上面的“好啊!(害羞.gif)”。 |
tag | 字符串。标记当前通知的标签。 |
icon | 字符串。通知面板左侧那个图标地址。 |
data | 任意类型和通知相关联的数据。 |
vibrate | 通知显示时候,设备震动硬件需要的振动模式。所谓振动模式,指的是一个描述交替时间的数组,分别表示振动和不振动的毫秒数,一直交替下去。例如[200, 100, 200]表示设备振动200毫秒,然后停止100毫秒,再振动200毫秒。 |
renotify | 布尔值。新通知出现的时候是否替换之前的。如果设为true ,则表示替换,表示当前标记的通知只会出现一个。注意都这里“当前标记”没?没错,true 参数要想其作用,必须tag 需要设置属性值。然后,通知就会像这样覆盖:
而不会是默认的叠高楼: |
silent | 布尔值。通知出现的时候,是否要有声音。默认false , 表示无声。 |
sound | 字符串。音频地址。表示通知出现要播放的声音资源。 |
noscreen | 布尔值。是否不再屏幕上显示通知信息。默认false , 表示要在屏幕上显示通知内容。
|
sticky | 布尔值。是否通知具有粘性,这样用户不太容易清除通知。默认false , 表示没有粘性。根据我自己的猜测,应该和position 的sticky 属性值类似。 |
4. Notification.close()
通知显示了,如何关闭呢?可以通过调用Notification.close()
实例方法,实际上,通知如果你放着不管,一段时间后就会自动隐藏,具体多久不详,我估摸着5秒有的。
5. 事件句柄
Notification.onclick
点击通知,然后……
Notification.onerror
通知显示异常,然后。例如,明明Notification.permission
是default
,你还让我显示。
下面这些呢有必要独立出来,虽然现在是支持挺好的,但是,由于目前规范并没有把它们列入其中,所以,未来有可能浏览器就不支持了。
Notification.onclose
通知关闭了,然后…… 无论是用户手动关闭,还是直接Notification.close()
关闭都会触发该该事件。
Notification.onshow
通知显示的时候,该干嘛干嘛~~
6. 其他属性值
除了Notification.permission
外,Notification
还有很多其他只读属性值,但是,基本上和上面的options
参数一致,返回的值也是options
和默认值的合并值(如果浏览器支持的话)。
Notification.title[只读]
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[只读]