The listener is passed the command's name. This matches the name given to the command in its manifest.json entry.
browser.commands.onCommand.addListener(listener) browser.commands.onCommand.removeListener(listener) browser.commands.onCommand.hasListener(listener)
Events have three functions:
addListener(callback)removeListener(listener)listener argument is the listener to remove.hasListener(listener)listener is registered for this event. Returns true if it is listening, false otherwise.callbackFunction that will be called when a user enters the command's shortcut. The function will be passed the following arguments:
namestring. Name of the command. This matches the name given to the command in its manifest.json entry.| Desktop | Mobile | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Chrome | Edge | Firefox | Internet Explorer | Opera | Safari | WebView Android | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | |
| onCommand | Yes | 79 | 48 Before version 63, the  onCommandlistener was not treated as a handler for a user action. | ? | Yes | 14 | ? | ? | No | ? | ? | ? | 
"commands": { "toggle-feature": { "suggested_key": { "default": "Ctrl+Shift+Y" }, "description": "Send a 'toggle-feature' event" } }
You could listen for this particular command like this:
browser.commands.onCommand.addListener(function(command) { if (command == "toggle-feature") { console.log("toggling the feature!"); } });
Note: This API is based on Chromium's chrome.commands API.
    © 2005–2021 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
    https://developer.mozilla.org/en-US/docs/Mozilla/Add-ons/WebExtensions/API/commands/onCommand