H5托盘通知(带声音提醒)

今天做了个仿网页版微信的托盘通知小例子,第一次写博客,直接上代码。
参考链接:
http://www.cnblogs.com/a14907/p/6472741.html----消息通知
https://www.helloweba.com/view-blog-220.html -----声音提醒
以下代码要在服务器上运行,才可以实现托盘通知的效果。
<script>
//添加声音文件
$('<audio id="chatAudio"><source src="notify.ogg" type="audio/ogg"><source src="/static/notify.wav" type="audio/mpeg"><source src="notify.wav" type="audio/wav"></audio>').appendTo('body');
//循环扫描通知条件
setInterval( function (){
$.post("/WebSite/postScan","",
function (data,status){
if (data.result=="1") {
noticeDisplay(data.msgtitle, data.bodycontent, data.iconImg, data.gotourl);
$('#chatAudio')[0].play(); //播放声音
}
});
},5000);
//H5托盘通知
function noticeDisplay(msgtitle,bodycontent,iconImg,gotourl) {
if (!window.Notification) {
alert("浏览器不支持通知!");
}
console.log(window.Notification.permission);
if (window.Notification.permission != 'granted') {
Notification.requestPermission( function (status) {
var permission = Notification.permission;
});
}
var n = new Notification(msgtitle,
{ "icon": iconImg, "body": bodycontent });
n.onshow = function () { console.log("显示通知");
setTimeout( function () { n.close() }, 5000); };
n.onclick = function () { window.open(gotourl); n.close(); };
n.onclose = function () { console.log("通知关闭"); };
n.onerror = function () { console.log('产生错误');};
}
</script>
后台java代码:
public Map postScan()
{
Map<String,String> keyValue=new HashMap<String,String>();
Date now=new Date();
Long time=now.getTime();
if(time%(1000*60*60)==0) {
keyValue.put("result", "1");
keyValue.put("msgtitle", "您收到一条新消息");
keyValue.put("bodycontent", "现在时间:"+now);
keyValue.put("iconImg", "");
keyValue.put("gotourl", "http://www.baidu.com");
}
else
{
keyValue.put("result", "0");
keyValue.put("msgtitle", "您收到一条新消息");
keyValue.put("bodycontent", "现在时间:"+now);
keyValue.put("iconImg", "");
keyValue.put("gotourl", "http://www.baidu.com");
}
return keyValue;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值