使用JavaScript实现网页通知功能

如何使用js来实现网页通知功能。即使在用户浏览其他页面时,也能向他们推送通知信息。

废话不多说直接上代码

typescript 复制代码
function showAutoNotification() {
  if ("Notification" in window) {
    Notification.requestPermission().then(function(permission) {
      if (permission === "granted") {
        var notification = new Notification("重 要 通 知", {
          body: "具体通知内容",
        });
        console.log("hook 200");
        setTimeout(function() {
          notification.close();
        }, 5500000);
        notification.onclick = function() {
          window.open("https://pan.zai1.com");
        };
      } else {
        alert("请打开网站通知,以便接收本站最新的消息。");
        console.log("当前浏览器禁止了网站推送");
      }
    });
  } else {
    console.log("当前浏览器不支持tuisong.js 请联系在意博客");
  }
}

setTimeout(showAutoNotification, 100);

代码解析如下:

检查浏览器是否支持Notification API。如果不支持,输出一条消息并停止执行。

请求用户的通知权限。

如果用户同意接收通知,创建并显示一个通知。通知的标题为"重 要 通 知",内容为"在意网盘,不限内容的网盘 pan.zai1.com"。

创建通知后,输出 "hook 200"。

5500000毫秒(约为91分钟)后,通知自动关闭。

如果用户点击通知,会打开"https://pan.zai1.com"这个网址。

如果用户没有同意接收通知,弹出一个提示对话框,并输出一条消息。

本函数被设置为在页面加载后的100毫秒后执行。

相关推荐
旭日猎鹰20 分钟前
Flutter踩坑记录(二)-- GestureDetector+Expanded点击无效果
前端·javascript·flutter
一条晒干的咸魚1 小时前
【Web前端】创建我的第一个 Web 表单
服务器·前端·javascript·json·对象·表单
花海少爷1 小时前
第十章 JavaScript的应用课后习题
开发语言·javascript·ecmascript
sinat_384241092 小时前
在有网络连接的机器上打包 electron 及其依赖项,在没有网络连接的机器上安装这些离线包
javascript·arcgis·electron
小牛itbull2 小时前
ReactPress vs VuePress vs WordPress
开发语言·javascript·reactpress
请叫我欧皇i2 小时前
html本地离线引入vant和vue2(详细步骤)
开发语言·前端·javascript
533_2 小时前
[vue] 深拷贝 lodash cloneDeep
前端·javascript·vue.js
GIS瞧葩菜2 小时前
局部修改3dtiles子模型的位置。
开发语言·javascript·ecmascript
zhang-zan3 小时前
nodejs操作selenium-webdriver
前端·javascript·selenium
ZBY520313 小时前
【Vue】 npm install amap-js-api-loader指南
javascript·vue.js·npm