地址栏按钮

通常来说的 page action,是添加到浏览器地址栏中的按钮。用户通过点击这个按钮与你的扩展进行交互。

地址栏按钮(Page actions)和工具栏按钮(browser actions)

地址栏按钮 (或 page action) 与工具栏按钮 (或 browser action) 非常相似。

其不同之处为:

  • 位置:
    • 地址栏按钮是显示在浏览器的地址栏内;
    • 工具栏按钮不是显示在地址栏内,而是在浏览器的工具栏上。
  • 可见性:
    • 地址栏按钮默认是隐藏的(尽管可以通过 manifest 中“show_matches 和 hide_matches 来改变),而你可以在特定 tabs 中调用 pageAction.show() 和 pageAction.hide() 来显示或隐藏它。
    • 工具栏按钮总是可见的。

当动作(行为)与当前页面关联时,使用地址栏按钮,而当动作(行为)与浏览器相关或与多个页面相关时使用工具栏按钮。例如:

类型 书签动作 内容动作 标签操作
page action 将本页面保存到书签 Reddit enhancement Send tab
browser action 显示所有书签 使能 ad-blocking 同步所有打开的标签

定义地址栏按钮

你可以在 manifest.json 中使用 page_action 键定义地址栏按钮的属性:

json
"page_action": {
  "browser_style": true,
  "default_icon": {
    "19": "button/geo-19.png",
    "38": "button/geo-38.png"
  },
  "default_title": "Whereami?"
}

仅 default_icon 是强制(必需)的。

有两种方式定义地址栏按钮:带 popup 窗口和无 popup 窗口。如果你没有指定一个 popup,则当用户点击此按钮时,事件被派送到使用pageAction.onClicked侦听器的扩展:

js
browser.pageAction.onClicked.addListener(handleClick);

如果你指定了一个 popup,则点击事件不被派送,在用户点击按钮时显示 popup。用户可以与 popup 进行交互,并且当用户点击 popup 以外区域时,popup 自动关闭。参见Popup可获得创建和管理 popups 更详细内容。

注意你的扩展只能有一个地址栏按钮。

通过使用pageAction API,你可以以编程方式修改地址栏按钮的任何属性。

Icons

如何创建用于地址栏按钮的 ICONS 的详细内容,请参见Photon Design System文档中的Iconography节。

示例

GitHub 上的 webextensions-examples 库中包括了实现无 popup 地址栏按钮的例子 chill-out