Electron中文手册
  • 文档概述
  • 开发指南目录
  • 构建说明(Linux)
  • 构建说明(macOS)
  • 构建说明(Windows)
  • 构建系统概述
  • 编码规范
  • 在 macOS 中调试
  • 在 Windows 中调试
  • 在C ++代码中使用clang-format
  • 在调试器中设置符号服务器
  • 源代码目录结构
  • Chrome升级清单
  • Chromium 开发指南
  • V8 开发指南
  • 教程目录
    • 关于 Electron
    • Electron 版本说明
    • API弃用说明
    • 快速入门
    • 支持的平台
    • 桌面环境集成
    • 系统通知
    • 离屏渲染
    • 在线/离线事件检测
    • 多线程
    • REPL
    • 键盘快捷键
    • DevTools扩展
    • 使用原生模块
    • 使用 Pepper Flash 插件
    • 使用 Selenium 和 WebDriver
    • 使用 Widevine CDM 插件
    • 应用分发
    • 应用打包
    • 主进程调试
    • 使用 node-inspector 进行主进程调试
    • 使用 VSCode 进行主进程调试
    • Mac App Store应用提交指南
    • Windows App Store应用提交指南
    • 安全,本地功能和你的责任
    • Headless CI Systems 测试
  • API接口目录
    • API接口之公用接口
      • 应用语言
      • 开发概要
      • 专业术语
      • 常见问题
      • 环境变量
      • 快捷键字符串
      • 命令行
      • 客户端请求
      • 剪贴板
      • <File> H5 File文件操作
      • 无框窗口
      • <window.open> window.open打开新窗口或打开时传递消息
      • 沙盒选项
    • API接口之主进程接口
      • 整体控制
      • 全局快捷键
      • 图标创建与应用
      • 屏幕
      • 窗口
      • 菜单
      • 菜单项
      • 系统托盘
      • 网页内容
      • 从主进程到渲染进程的异步通信
      • 对话框
      • 创建和控制视图
      • 会话
      • 会话,缓存和代理等控制
      • 页面请求
      • HTTP/HTTPS请求处理
      • 协议的注册和处理
      • 使用系统默认应用程序管理文件或URL
      • 下载项管理
      • 进程控制
      • Chromium原生网络库
      • 获取系统首选项
      • 电源状态
      • 节能管理
      • 调试工具
      • 奔溃报告
      • 性能数据收集
      • 自动更新
      • TouchBar触摸条
      • TouchBar触摸条按钮
      • TouchBar触摸条拾色器
      • TouchBar触摸条分组
      • TouchBar触摸条scrubber
      • TouchBar触摸条分段控件
      • TouchBar触摸条label标签
      • TouchBar触摸条弹出框
      • TouchBar触摸条滑块
      • TouchBar触摸条间隔符
    • API接口之渲染进程接口
      • 页面渲染
      • <webview> webview标签
      • 渲染进程与主进程通信
      • 从渲染进程到主进程的异步通信
      • 子窗口
      • 捕获桌面资源
  • 结构列表
    • 蓝牙设备对象
    • 证书对象
    • 证书主体对象
    • Cookie对象
    • 崩溃报告对象
    • 桌面捕获源对象
    • 显示器对象
    • 打印机信息对象
    • 文件过滤器对象
    • 最近使用的项目
    • 常用列表项
    • CPU使用率对象即程序占用的CPU资源
    • IO值对象
    • 内存信息对象
    • 进程内存信息对象
    • 内存使用详细信息
    • Mime类型缓冲区
    • 矩形对象
    • 删除客户端证书对象
    • 删除密码对象
    • Scrubber项对象
    • 分段控制对象
    • 快捷方式对象
    • 任务对象
    • 缩略图工具栏按钮对象
    • 上传blob对象
    • 上传数据对象
    • 上传文件系统对象
    • 上传文件对象
    • 上传原始数据对象
Powered by GitBook
On this page
  • Windows
  • Windows中的高级通知
  • macOS
  • macOS中的高级通知
  • Windows和macOS检测系统是否支持收发通知(静默/演示模式)
  • Linux

Was this helpful?

  1. 教程目录

系统通知

Previous桌面环境集成Next离屏渲染

Last updated 4 years ago

Was this helpful?

这三个系统都为应用提供了向用户发送通知的API。 Electron允许开发人员使用快速发送通知,并通过当前系统的自带通知API来显示。

注意: 由于这是一个HTML5 API,因此它仅在渲染器进程中可用

let myNotification = new Notification('测试标题', {
  body: '测试通知'
})

myNotification.onclick = () => {
  console.log('通知已被点击')
}

虽然跨操作系统的代码和用户体验基本相似,但还是有一些差异。

Windows

  • 在Windows 10中, 可正常通知.

  • 在Windows 8.1 或 Windows 8中, 需要先使用将快捷方式创建到开始屏幕上.

  • 在Windows 7中, 无法使用通知. 不过你可以使用发送一个 气泡通知.

另外,在Win8中,通知内容长度不超过250个字节,Windows团队建议小于200个字符.虽然Win10删除了这个限制,但是如果发送过如上千字的长文本将导致异常.

Windows中的高级通知

最新版本的Windows支持使用图文影像元素等自定义模板的高级通知.如需使用此类通知,您可以使用模块来发送 ToastNotification 和 TileNotification 对象进行实现.

macOS

另外,通知内容长度不超过256个字节

macOS中的高级通知

Windows和macOS检测系统是否支持收发通知(静默/演示模式)

Linux

通知使用 libnotify进行发送, 只要桌面环境支持 [桌面通知规范][notification-spec]即可正常显示, 包括 Cinnamon, Enlightenment, Unity, GNOME, KDE.

仅仅通知则只需要 electron-windows-notifications就够了, 但是想要处理答复的话,您需要使用模块进行注册COM组件并根据输入数据调用Electron应用来实现.

MacOS上的通知是直接转发的,但您应该了解

最新版本的macOS支持发送带有快速回复的输入框的通知,如需要这一功能,请使用实现

您可以使用模块检测系统是否允许收发通知,这样就可以避免Windows默认忽略通知的情况.

[notification-spec]:

electron-windows-interactive-notifications
Apple关于通知的人机接口指南
node-mac-notifier
electron-notification-state
https://developer.gnome.org/notification-spec/
HTML5 Notification API
Application User Model ID
electron-windows-notifications
Tray API