Web Notifications API-让网页也能像QQ一样实现消息通知

一.什么是Web Notifications API

Web Notifications API允许网页或者是应用程序以系统级别发送在页面外部显示的通知,这样就可以实现即时应用程序在后台或者是空闲状态,Web应用程序也会向用户发送信息。

二.Notification的状态

1.denied(拒绝)------不允许发送通知

2.granted(同意)------允许发送通知

3.default(默认状态)------根据浏览器来决定,一般是询问浏览器,来请求获取发送通知的权限

三.场景实现步骤

1.检查浏览器是否支持

2.首先请求权限,在应用程序可以发送通知之前,需要用户授予应用程序发生通知的权限

3.创建并显示通知

具体实现代码

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Notification Example</title>
<script>
// 当页面加载时执行
document.addEventListener('DOMContentLoaded', function() {
  // 检查浏览器是否支持Notification API
  if (!("Notification" in window)) {
    alert("This browser does not support desktop notification");
  }
  // 检查用户是否已经授予权限
  else if (Notification.permission === "granted") {
    // 如果已经授权,可以直接显示通知
    showNotification();
  }

  // 如果用户尚未做出选择或默认为'default',则请求权限
  else if (Notification.permission !== "denied") {
    Notification.requestPermission().then(function(permission) {
      // 一旦用户响应,可以显示通知
      if (permission === "granted") {
        showNotification();
      }
    });
  }

  // 显示通知的函数
  function showNotification() {
    var notification = new Notification("Hello", {
      body: "This is a notification message!",
      icon: 'icon.png' // 路径到图标文件
    });

    // 可以添加事件监听器来处理用户交互
    notification.onclick = function() {
      // 这里可以打开新窗口或跳转到特定页面
      window.open('https://www.example.com', '_blank');
    };
  }
});
</script>
</head>
<body>
<h1>Web Notifications API Example</h1>
<p>Check the top-right corner for the notification!</p>
</body>
</html>

四.优缺点:

优点:1.可以定制通知的外观和行为

2.不需要用户授权

3.可以应用到现有的网页设计中

缺点:1.需要适配移动端设备

2.过多的使用可能会影响页面性能。

相关推荐
终端鹿3 小时前
Suspense 异步组件与懒加载实战
前端·vue.js
清风细雨_林木木3 小时前
CSS 报错:css-semicolonexpected 解决方案
前端·css
Jinuss3 小时前
源码分析之React中useRef解析
前端·javascript·react.js
cch89183 小时前
css 样式说明,在页面布局开发中,样式表用于控制组件的尺寸、间距、边框及背景等视觉表现
前端·javascript·html
被AI抢饭碗的人3 小时前
QT:基础与信号槽
前端·qt
熙街丶一人3 小时前
css 图片未加载时默认高度,加载后随图片高度
前端·javascript·css
xiaoliuliu123453 小时前
Android Studio 2025 安装教程:详细步骤+自定义安装路径+SDK配置(附桌面快捷方式创建)
java·前端·数据库
紫_龙3 小时前
最新版vue3+TypeScript开发入门到实战教程之Pinia详解
前端·javascript·typescript
533_3 小时前
[echarts] 使用scss变量
前端·echarts·scss
小李云雾3 小时前
零基础-从ESS6基础到前后端联通实战
前端·python·okhttp·中间件·eclipse·html·fastapi