跳转到主要内容

通知

每个操作系统都有自己向用户显示通知的机制。Electron 的通知 API 是跨平台的,但对于每种进程类型都不同。

如果你想在主进程中使用渲染器进程的 API,反之亦然,请考虑使用进程间通信

用法

下面是两个示例,展示了如何为每种进程类型显示通知。

在主进程中显示通知

主进程通知使用 Electron 的 Notification 模块来显示。使用此模块创建的通知对象只有在调用其 show() 实例方法后才会出现。

主进程
const { Notification } = require('electron')

const NOTIFICATION_TITLE = 'Basic Notification'
const NOTIFICATION_BODY = 'Notification from the Main process'

new Notification({
title: NOTIFICATION_TITLE,
body: NOTIFICATION_BODY
}).show()

这是一个完整的示例,你可以使用 Electron Fiddle 打开它

const { app, BrowserWindow, Notification } = require('electron/main')

function createWindow () {
const win = new BrowserWindow({
width: 800,
height: 600
})

win.loadFile('index.html')
}

const NOTIFICATION_TITLE = 'Basic Notification'
const NOTIFICATION_BODY = 'Notification from the Main process'

function showNotification () {
new Notification({ title: NOTIFICATION_TITLE, body: NOTIFICATION_BODY }).show()
}

app.whenReady().then(createWindow).then(showNotification)

app.on('window-all-closed', () => {
if (process.platform !== 'darwin') {
app.quit()
}
})

app.on('activate', () => {
if (BrowserWindow.getAllWindows().length === 0) {
createWindow()
}
})

在渲染器进程中显示通知

通知可以直接通过渲染器进程使用 Web Notifications API 来显示。

渲染器进程
const NOTIFICATION_TITLE = 'Title'
const NOTIFICATION_BODY =
'Notification from the Renderer process. Click to log to console.'
const CLICK_MESSAGE = 'Notification clicked'

new Notification(NOTIFICATION_TITLE, { body: NOTIFICATION_BODY }).onclick =
() => console.log(CLICK_MESSAGE)

这是一个完整的示例,你可以使用 Electron Fiddle 打开它

const NOTIFICATION_TITLE = 'Title'
const NOTIFICATION_BODY = 'Notification from the Renderer process. Click to log to console.'
const CLICK_MESSAGE = 'Notification clicked!'

new window.Notification(NOTIFICATION_TITLE, { body: NOTIFICATION_BODY })
.onclick = () => { document.getElementById('output').innerText = CLICK_MESSAGE }

平台注意事项

虽然不同操作系统的代码和用户体验相似,但仍存在一些细微差别。

Windows

对于 Windows 上的通知,你的 Electron 应用程序需要在开始菜单中有一个包含 AppUserModelID 和相应 ToastActivatorCLSID 的快捷方式。

Electron 试图自动化与 AppUserModelID 和 ToastActivatorCLSID 相关的工作。当 Electron 与 Squirrel.Windows 一起使用时(例如,如果你正在使用 electron-winstaller),快捷方式将自动被正确设置

在生产环境中,Electron 也会检测到 Squirrel 的使用,并自动使用正确的值调用 app.setAppUserModelId()。在开发过程中,你可能需要自己调用 app.setAppUserModelId()

开发中的通知

为了在开发过程中快速启用通知,将 node_modules\electron\dist\electron.exe 添加到你的开始菜单也是一个有效的方法。在文件资源管理器中找到该文件,右键单击并选择“固定到‘开始’屏幕”。然后,在主进程中调用 app.setAppUserModelId(process.execPath) 以查看通知。

使用高级通知

Windows 还允许使用自定义模板、图像和其他灵活元素的高级通知。

要从主进程发送这些通知,你可以使用社区模块 electron-windows-notifications,它使用原生 Node 插件来发送 ToastNotificationTileNotification 对象。

虽然包含按钮的通知可以使用 electron-windows-notifications,但处理回复需要使用 electron-windows-interactive-notifications,它有助于注册所需的 COM 组件并使用用户输入的数据调用你的 Electron 应用程序。

查询通知状态

要检测是否允许发送通知,请使用社区模块 windows-notification-state

该模块可以让你提前确定 Windows 是否会静默地丢弃通知。

macOS

在 macOS 上,通知的使用非常直接,但你应该了解苹果关于通知的人机界面指南

请注意,通知的大小限制为 256 字节,如果超过该限制,内容将被截断。

查询通知状态

要检测是否允许发送通知,请使用社区模块 macos-notification-state

该模块可以让你提前检测通知是否会被显示。

Linux

通知使用 libnotify 发送,它可以在任何遵循桌面通知规范的桌面环境中显示通知,包括 Cinnamon、Enlightenment、Unity、GNOME 和 KDE。