action.onClicked
当浏览器操作图标被点击时触发。如果浏览器操作有一个弹出窗口,此事件将不会触发。
备注: 该 API 在 Manifest V3 或更高版本中可用。
要定义右键单击操作,请使用“browser_action”上下文类型的 contextMenus API。
语法
js
browser.action.onClicked.addListener(listener)
browser.action.onClicked.removeListener(listener)
browser.action.onClicked.hasListener(listener)
事件包含三个函数:
addListener(listener)-
为此事件添加监听器。
removeListener(listener)-
停止监听此事件。
listener参数是要移除的监听器。 hasListener(listener)-
检查是否已为此事件注册了
listener。如果正在监听,则返回true,否则返回false。
addListener 语法
>参数
listener-
该函数将在事件触发时被调用。会为该函数传递以下参数:
tab-
tabs.Tab,当图标被点击时的活动标签页。 OnClickData-
包含有关点击的信息的对象。
modifiers-
array,点击时活动的键盘修饰符,可以是Shift、Alt、Command、Ctrl或MacCtrl中的一个或多个。 -
integer,指示用于点击页面操作图标的按钮:0表示左键点击或不是鼠标的点击,例如键盘点击,1表示中键或滚轮点击。请注意,不支持右键点击,因为 Firefox 在触发此事件之前会消耗该点击以显示上下文菜单。
示例
当用户点击图标时,禁用当前标签页,并记录标签页的 URL:
js
browser.action.onClicked.addListener((tab) => {
// 禁用活动标签页
browser.action.disable(tab.id);
// 需要“tabs”或“activeTab”权限,或对该 URL 的“host”权限。
console.log(tab.url);
});
浏览器兼容性
Loading…
备注:
此 API 基于 Chromium 的 chrome.action API。该文档衍生自 Chromium 代码中的 browser_action.json。