Web Notification桌面消息推送
2018-06-04 本文已影响208人
会飞的猪l
HTML5特性之Notification桌面消息推送
兼容Chrome和Firefox
消息推送会默认需要授权,对一些不安全的网页默认关闭
主要通过Notification下面的permission属性:permission只读属性
default 用户没有接收或拒绝授权 不能显示通知
granted 用户接受授权 允许显示通知
denied 用户拒绝授权 不允许显示通知
在浏览器载入的时候就可以判断
if(window.Notification.permission=="default"){
//如果没有开启,something
}
具体实现代码
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
</head>
<script src="js/jquery-1.11.3.js" type="text/javascript" charset="utf-8"></script>
<body>
<button id="showNoti">显示通知</button>
</body>
<script type="text/javascript">
$(function () {
$("#showNoti").click(function () {
if (!window.Notification) {
alert("浏览器不支持通知!");
}
console.log(window.Notification.permission);
if (window.Notification.permission != 'granted') {
Notification.requestPermission(function (status) {
//status是授权状态,如果用户允许显示桌面通知,则status为'granted'
console.log('status: ' + status);
//permission只读属性:
// default 用户没有接收或拒绝授权 不能显示通知
// granted 用户接受授权 允许显示通知
// denied 用户拒绝授权 不允许显示通知
var permission = Notification.permission;
console.log('permission: ' + permission);
});
}
var n = new Notification("您有一条消息!", { "icon": "", "body": "您一分钟后将有好运气" });
n.onshow = function () {
console.log("显示通知");
setTimeout(function () { n.close() }, 3000); };
n.onclick = function () { alert("打开相关视图");
window.open("/Home/about"); n.close();
};
n.onclose = function () { console.log("通知关闭"); };
n.onerror = function () { console.log('产生错误'); };
});
});
</script>
</html>
image.png