自 Chrome 59 版起,透過 Notifications API 或 chrome.notifications extensions API 傳送的通知,將直接由 macOS 原生通知系統顯示,而非 Chrome 本身的系統。
這項變更可讓 macOS 上的 Chrome 與平台整合得更好,並修正多項長期存在的錯誤,例如 Chrome 不遵循系統「請勿打擾」設定。
以下我們將探討這項變更對現有 API 的影響。
通知中心
這項異動的好處之一,就是通知會顯示在 macOS 的通知中心。
data:image/s3,"s3://crabby-images/fa0f1/fa0f1b7e8c7b6d2eb01be0bf954c056d2583f97d" alt="Google Chrome 通知會顯示在 macOS 通知中心"
相異處
圖示大小和位置
圖示的外觀將有所變動。它們會變小,並套用邊框間距。建議您改用透明背景圖示,而非純色,以便營造美觀的視覺效果。
data:image/s3,"s3://crabby-images/7857c/7857cce9b59429578f20ad3d1ba6029a6fe8b3a9" alt="在 Mac 上使用 Chrome 前後的通知圖示:Chrome 顯示的圖示與 macOS 顯示的圖示。"
動作圖示
在這項變更之前,通知會顯示動作按鈕和圖示。使用原生通知時,系統不會使用動作按鈕圖示,使用者必須將滑鼠游標懸停在通知上,然後選取「更多」按鈕,才能查看可用的動作。
data:image/s3,"s3://crabby-images/83594/835941de976607deda95d53e00cd7eadfadb97e0" alt="通知動作按鈕的「前」與「後」比較,顯示 Chrome 和 macOS 的圖示。"
Chrome 標誌
Chrome 標誌一律會顯示,且無法取代或變更。這是 macOS 上第三方應用程式的要求。
圖片
macOS 將不再支援 image
選項。如果您定義圖片屬性,系統仍會顯示通知,但會忽略圖片參數 (請參閱下方範例)。
data:image/s3,"s3://crabby-images/be0a6/be0a619b3c5c78ebc00960e2cee4114415f02488" alt="macOS 版 Chrome 的通知圖片前後對照。"
您可以使用以下程式碼支援圖片偵測功能:
if ('image' in Notification.prototype) {
// Image is supported.
} else {
// Image is NOT supported.
}
Chrome 擴充功能變更
Chrome 擴充功能有通知範本的概念,這項功能會因這項異動而有所不同。
圖片通知範本將不再顯示圖片。請確保圖片是輔助性質,並非使用者必須用來取得資訊。
data:image/s3,"s3://crabby-images/a4928/a4928869ebc5a4188ab6cdf0d760d5e02db46e5a" alt="chrome.notification API 中的圖片範本前後對照。"
清單通知範本只會顯示清單中的首個項目。您可以考慮改回基本通知樣式,並使用內文文字來總結一組變更。
data:image/s3,"s3://crabby-images/4de73/4de73c146209e82d70ec1e3489b80353652d227f" alt="chrome.notification API 中的清單範本前後。"
進度通知會在通知標題中附加百分比值,用來表示進度,而非進度列。
data:image/s3,"s3://crabby-images/a4494/a4494b01d8ba08587fc57f2261d0bad3e2b9907b" alt="chrome.notification API 中進度範本的前後。"
通知 UI 的最後一個差異是,appIconMarkUrl
將不再用於 macOS。
data:image/s3,"s3://crabby-images/5b5c2/5b5c26e9588c67397d287c7f8f949f03f65c7c61" alt="chrome.notification API 中的 appIconMarkUrl 前後。"