使用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毫秒后执行。

相关推荐
xiaoqi92227 分钟前
React Native鸿蒙跨平台如何实现分类页面组件通过searchQuery状态变量管理搜索输入,实现了分类的实时过滤功能
javascript·react native·react.js·ecmascript·harmonyos
qq_177767371 小时前
React Native鸿蒙跨平台实现应用介绍页,实现了应用信息卡片展示、特色功能网格布局、权限/联系信息陈列、评分展示、模态框详情交互等通用场景
javascript·react native·react.js·ecmascript·交互·harmonyos
2603_949462101 小时前
Flutter for OpenHarmony社团管理App实战:预算管理实现
android·javascript·flutter
wuhen_n1 小时前
JavaScript内存管理与执行上下文
前端·javascript
Hi_kenyon1 小时前
理解vue中的ref
前端·javascript·vue.js
jin1233222 小时前
基于React Native鸿蒙跨平台地址管理是许多电商、外卖、物流等应用的重要功能模块,实现了地址的添加、编辑、删除和设置默认等功能
javascript·react native·react.js·ecmascript·harmonyos
2501_920931703 小时前
React Native鸿蒙跨平台医疗健康类的血压记录,包括收缩压、舒张压、心率、日期、时间、备注和状态
javascript·react native·react.js·ecmascript·harmonyos
橙露4 小时前
React Hooks 深度解析:从基础使用到自定义 Hooks 的封装技巧
javascript·react.js·ecmascript
2501_920931704 小时前
React Native鸿蒙跨平台使用useState管理健康记录和过滤状态,支持多种健康数据类型(血压、体重等)并实现按类型过滤功能
javascript·react native·react.js·ecmascript·harmonyos
Ulyanov4 小时前
从静态到沉浸:打造惊艳的Web技术发展历程3D时间轴
前端·javascript·html5·gui开发