0

0

javascript怎样操作浏览器通知?_javascript的Notification API如何请求权限?

幻影之瞳

幻影之瞳

发布时间:2025-12-18 23:15:07

|

700人浏览过

|

来源于php中文网

原创

JavaScript 使用 Notification API 发送浏览器通知,需用户授权且仅限 HTTPS 或 localhost;调用 requestPermission() 请求权限,检查 permission 状态后创建通知,并监听 onclick 等事件。

javascript怎样操作浏览器通知?_javascript的notification api如何请求权限?

JavaScript 操作浏览器通知主要靠 Notification API,它允许网页向用户发送系统级通知(即使页面不在前台)。但必须先获得用户授权,且仅在安全上下文(https://localhost)中可用。

如何请求通知权限?

调用 Notification.requestPermission() 发起权限请求。该方法返回一个 Promise,在现代浏览器中推荐用 await 处理:

  • 用户首次访问时会弹出浏览器原生权限提示(如“是否允许此网站发送通知?”)
  • 返回值是 "granted""denied""default"(已废弃,现统一为 "prompt"
  • 不能自动触发,必须由用户手势(如点击按钮)触发,否则会被静默拒绝

示例:

document.getElementById('notifyBtn').addEventListener('click', async () => {
  const permission = await Notification.requestPermission();
  if (permission === 'granted') {
    new Notification('你好!', { body: '这是一条通知' });
  } else {
    console.log('用户拒绝了通知权限');
  }
});

如何检查当前权限状态?

使用 Notification.permission 可读取当前状态,无需再次请求:

立即学习Java免费学习笔记(深入)”;

  • "granted":已授权,可直接发通知
  • "denied":被拒绝,后续调用 requestPermission() 不会再弹窗
  • "prompt":未决定,可调用 requestPermission() 弹出授权框

建议每次发通知前都检查该值,避免无意义调用。

LLaMA
LLaMA

Meta公司发布的下一代开源大型语言模型

下载

如何创建和自定义通知?

权限获准后,用 new Notification(title, options) 创建通知:

  • title:必填,显示在通知顶部的标题文本
  • options:对象,常用字段包括:
      – body:正文内容
      – icon:图标 URL(建议 192×192 或 512×512 PNG)
      – badge:小图标(用于 Android 或桌面通知栏摘要)
      – requireInteraction:设为 true 可阻止通知自动关闭

注意:部分选项(如 sound)已被主流浏览器移除,不再支持。

如何监听通知生命周期事件?

通知实例提供几个事件回调,可用于增强交互:

  • onclick:用户点击通知时触发(常用于跳转页面)
  • onshow:通知成功显示后触发
  • onerror:通知因权限/参数等问题失败时触发
  • onclose:用户手动关闭或超时自动关闭后触发

示例:

const n = new Notification('新消息', { body: '点击查看' });
n.onclick = () => window.focus(); // 点击后聚焦当前窗口

基本上就这些。关键点是:权限需用户主动授予、必须 HTTPS/localhost、不能绕过交互触发、通知内容要简洁明确。

相关文章

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
default gateway怎么配置
default gateway怎么配置

配置default gateway的步骤:1、了解网络环境;2、获取路由器IP地址;3、登录路由器管理界面;4、找到并配置WAN口设置;5、配置默认网关;6、保存设置并退出;7、检查网络连接是否正常。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

223

2023.12.07

promise的用法
promise的用法

“promise” 是一种用于处理异步操作的编程概念,它可以用来表示一个异步操作的最终结果。Promise 对象有三种状态:pending(进行中)、fulfilled(已成功)和 rejected(已失败)。Promise的用法主要包括构造函数、实例方法(then、catch、finally)和状态转换。

307

2023.10.12

html文本框类型介绍
html文本框类型介绍

html文本框类型有单行文本框、密码文本框、数字文本框、日期文本框、时间文本框、文件上传文本框、多行文本框等等。详细介绍:1、单行文本框是最常见的文本框类型,用于接受单行文本输入,用户可以在文本框中输入任意文本,例如用户名、密码、电子邮件地址等;2、密码文本框用于接受密码输入,用户在输入密码时,文本框中的内容会被隐藏,以保护用户的隐私;3、数字文本框等等。

409

2023.10.12

android开发三大框架
android开发三大框架

android开发三大框架是XUtil框架、volley框架、ImageLoader框架。本专题为大家提供android开发三大框架相关的各种文章、以及下载和课程。

293

2023.08.14

android是什么系统
android是什么系统

Android是一种功能强大、灵活可定制、应用丰富、多任务处理能力强、兼容性好、网络连接能力强的操作系统。本专题为大家提供android相关的文章、下载、课程内容,供大家免费下载体验。

1757

2023.08.22

android权限限制怎么解开
android权限限制怎么解开

android权限限制可以使用Root权限、第三方权限管理应用程序、ADB命令和Xposed框架解开。详细介绍:1、Root权限,通过获取Root权限,用户可以解锁所有权限,并对系统进行自定义和修改;2、第三方权限管理应用程序,用户可以轻松地控制和管理应用程序的权限;3、ADB命令,用户可以在设备上执行各种操作,包括解锁权限;4、Xposed框架,用户可以在不修改系统文件的情况下修改应用程序的行为和权限。

2050

2023.09.19

android重启应用的方法有哪些
android重启应用的方法有哪些

android重启应用有通过Intent、PendingIntent、系统服务、Runtime等方法。本专题为大家提供Android相关的文章、下载、课程内容,供大家免费下载体验。

277

2023.10.18

Android语音播放功能实现方法
Android语音播放功能实现方法

实现方法有使用MediaPlayer实现、使用SoundPool实现两种。可以根据具体的需求选择适合的方法进行实现。想了解更多语音播放的相关内容,可以阅读本专题下面的文章。

351

2024.03.01

AO3官网入口与中文阅读设置 AO3网页版使用与访问
AO3官网入口与中文阅读设置 AO3网页版使用与访问

本专题围绕 Archive of Our Own(AO3)官网入口展开,系统整理 AO3 最新可用官网地址、网页版访问方式、正确打开链接的方法,并详细讲解 AO3 中文界面设置、阅读语言切换及基础使用流程,帮助用户稳定访问 AO3 官网,高效完成中文阅读与作品浏览。

89

2026.02.02

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 4.5万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.6万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号