
JavaScript 实现推送通知主要依赖两个核心机制:浏览器原生的 Notification API(用于显示本地通知)和 Push API + Service Worker(用于接收服务器发起的后台推送)。很多人混淆二者,这里先明确:Notification API 本身不收消息,只负责“显示”;真正实现远程推送必须配合 Push API 和后台服务。
一、启用 Notification API(用户授权与显示)
这是推送功能的第一步,必须获得用户明确授权才能显示通知:
- 调用
Notification.requestPermission()弹出浏览器权限请求框(仅在用户交互后如点击按钮中调用才有效) - 检查返回值是否为
"granted",只有授权成功才能创建通知 - 使用
new Notification(title, options)创建并显示通知,支持图标、正文、声音(需用户设置)、重定向链接等
示例代码:
document.getElementById('notify-btn').onclick = async () => {
const permission = await Notification.requestPermission();
if (permission === 'granted') {
new Notification('你好!', {
body: '这是一条前端触发的通知',
icon: '/icon.png',
tag: 'welcome'
});
}
};登录后复制
二、实现真正的远程推送(Push API + Service Worker)
要让页面关闭后也能收到通知,必须走 Push 流程:
标签: javascript java js 前端 json 浏览器 safari 后端 ai win 常见问题
还木有评论哦,快来抢沙发吧~