notifications.getAll()

获取由当前扩展创建的所有当前活动通知。

这是一个返回 Promise 的异步函数。

语法

js
let gettingAll = browser.notifications.getAll()

参数

无。

返回值

Promise,将会以一个对象兑现。所有的活动通知都会是该对象的一个属性,其中属性名为通知 ID 而属性值为描述该通知的 notifications.NotificationOptions 对象。

需要注意,你可以通过将 ID 传递给 notifications.create() 来显式定义通知的 ID。如果你不这样做,浏览器会生成一个 ID。显式指定的 ID 是字符串,而生成的 ID 是数字。

浏览器兼容性

BCD tables only load in the browser

示例

下属示例在用户点击浏览器操作时显示一个通知(如果通知已经在显示了则会清除这一通知)。它使用 getAll() 来判断通知是否正在显示:

js
const myNotification = "my-notification";

function toggleAlarm(all) {
  const ids = Object.keys(all);
  if (ids.includes(myNotification)) {
    browser.notifications.clear(myNotification);
  } else {
    console.log("显示");

    browser.notifications.create(myNotification, {
      type: "basic",
      title: "一个令人印象深刻的标题",
      message: "一些有意思的文本内容",
    });
  }
}

function handleClick() {
  console.log("被点击");
  browser.notifications.getAll().then(toggleAlarm);
}

browser.browserAction.onClicked.addListener(handleClick);

下述示例则打印所有活动通知的标题:

js
function logNotifications(all) {
  for (const id in all) {
    console.log(`标题:${all[id].title}`);
  }
}

browser.notifications.getAll().then(logNotifications);

备注: 该 API 基于 Chromium 的 chrome.notifications API。