browserAction.onClicked
Fired when a browser action icon is clicked. This event will not fire if the browser action has a popup.
To define a right-click action, use the contextMenus
API with the "browser_action" context type.
Syntax
js
browser.browserAction.onClicked.addListener(listener)
browser.browserAction.onClicked.removeListener(listener)
browser.browserAction.onClicked.hasListener(listener)
Events have three functions:
addListener(listener)
-
Adds a listener to this event.
removeListener(listener)
-
Stop listening to this event. The
listener
argument is the listener to remove. hasListener(listener)
-
Check whether
listener
is registered for this event. Returnstrue
if it is listening,false
otherwise.
addListener syntax
Parameters
listener
-
The function called when this event occurs. The function is passed these arguments:
tab
-
tabs.Tab
. The tab that was active when the icon was clicked. OnClickData
-
An object containing information about the click.
modifiers
-
An
array
. The keyboard modifiers active at the time of the click, being one or more ofShift
,Alt
,Command
,Ctrl
, orMacCtrl
. -
An
integer
. Indicates the button used to click the page action icon:0
for a left-click or a click not associated with a mouse, such as one from the keyboard and1
for a middle button or wheel click. Note that the right-click is not supported because Firefox consumes that click to display the context menu before this event is triggered.
Browser compatibility
BCD tables only load in the browser
Examples
When the user clicks the icon, disable it for the active tab, and log the tab's URL:
js
browser.browserAction.onClicked.addListener((tab) => {
// disable the active tab
browser.browserAction.disable(tab.id);
// requires the "tabs" or "activeTab" permission, or host permissions for the URL
console.log(tab.url);
});
Example extensions
- bookmark-it
- favourite-colour
- find-across-tabs
- forget-it
- google-userinfo
- native-messaging
- open-my-page-button
- permissions
- runtime-examples
- store-collected-images
Note:
This API is based on Chromium's chrome.browserAction
API. This documentation is derived from browser_action.json
in the Chromium code.