从 Chrome 59 开始,通过 Notifications API 或 chrome.notifications extensions API 发送的通知将直接由 macOS 原生通知系统显示,而不是由 Chrome 自己的系统显示。
此项更改让 macOS 上的 Chrome 与平台的集成更加紧密,并修复了一些长期存在的 bug,例如 Chrome 不遵循系统勿扰模式设置。
下面,我们将了解此更改对现有 API 带来的差异。
通知中心
此项变更的一个好处是,通知将显示在 macOS 的通知中心内。
data:image/s3,"s3://crabby-images/c5a4f/c5a4f2b0a42671be5dd1e220981cff66fa488ea6" alt="Google Chrome 通知将显示在 macOS 通知中心内"
不同之处
图标大小和位置
图标的外观将发生变化。它们的大小会更小,并且会应用内边距。为了美观起见,您不妨考虑改用透明背景图标,而不是纯色图标。
data:image/s3,"s3://crabby-images/ba827/ba827ba0da6bd27b20a61a6848afe49dd06a5326" alt="在 Mac 上使用 Chrome 前后的通知图标对比:由 Chrome 显示的通知图标与由 macOS 显示的通知图标。"
操作图标
在此变更生效之前,通知中会显示操作按钮和图标。对于原生通知,系统不会使用操作按钮图标,用户需要将鼠标悬停在通知上,然后选择“更多”按钮才能查看可用操作。
data:image/s3,"s3://crabby-images/f0107/f0107a8e0d6f7d1427c25f659a9655af8c5c4948" alt="通知操作按钮的图标在 Chrome 和 macOS 中显示的前后对比。"
Chrome 徽标
Chrome 徽标将始终显示,且无法替换或更改。这是 macOS 上第三方应用的要求。
图片
macOS 不再支持 image
选项。如果您定义了图片属性,系统仍会显示通知,但会忽略图片参数(请参阅以下示例)。
data:image/s3,"s3://crabby-images/dbaa3/dbaa3a8aa5d076ffd8e6aaec19c66d87e39c4e78" alt="macOS 上 Chrome 通知图片的更新前后对比。"
您可以使用以下代码检测图片支持情况:
if ('image' in Notification.prototype) {
// Image is supported.
} else {
// Image is NOT supported.
}
Chrome 扩展程序变更
Chrome 扩展程序具有通知模板的概念,此概念在此次变更后将会表现出不同的行为。
图片通知模板将不再显示图片。您应确保图片是补充性图片,对用户而言不是必需的。
data:image/s3,"s3://crabby-images/7f6ba/7f6baccbfe0d1072e57c465d41048be1d6aa440c" alt="chrome.notification API 中图片模板的修改前后对比。"
列表通知模板只会显示列表中的第一项。您不妨考虑改回基本通知样式,并使用正文文本总结一组更改。
data:image/s3,"s3://crabby-images/106f6/106f60f54fb6f66b05f3b40cc46688790c234d37" alt="chrome.notification API 中列表模板的之前和之后。"
进度通知会在通知标题中附加百分比值来指示进度,而不是显示进度条。
data:image/s3,"s3://crabby-images/4e7ac/4e7ac32adeecbd95aba8aadd9e2ee8b17b614908" alt="chrome.notification API 中进度模板的之前和之后。"
通知界面中的最后一项差异是,appIconMarkUrl
将不再在 macOS 上使用。
data:image/s3,"s3://crabby-images/9266b/9266b60ea120785f988fab7609887b046d7060be" alt="chrome.notification API 中 appIconMarkUrl 的使用前后对比。"