Description
Utilisez l'API Commands pour ajouter des raccourcis clavier qui déclenchent des actions dans votre extension, par exemple une action pour ouvrir l'action du navigateur ou envoyer une commande à l'extension.
Fichier manifeste
Pour utiliser cette API, vous devez déclarer les clés suivantes dans le fichier manifeste.
"commands"
Concepts et utilisation
L'API Commands permet aux développeurs d'extensions de définir des commandes spécifiques et de les associer à une combinaison de touches par défaut. Chaque commande acceptée par une extension doit être déclarée en tant que propriétés de l'objet "commands"
dans le fichier manifeste de l'extension.
La clé de propriété est utilisée comme nom de la commande. Les objets de commande peuvent prendre deux propriétés.
suggested_key
Propriété facultative qui déclare les raccourcis clavier par défaut pour la commande. Si cette option est omise, la commande n'est pas liée. Cette propriété peut prendre une chaîne ou une valeur d'objet.
Une valeur de chaîne spécifie le raccourci clavier par défaut à utiliser sur toutes les plates-formes.
Une valeur d'objet permet au développeur de l'extension de personnaliser le raccourci clavier pour chaque plate-forme. Lorsque vous fournissez des raccourcis spécifiques à la plate-forme, les propriétés d'objet valides sont
default
,chromeos
,linux
,mac
etwindows
.
Pour en savoir plus, consultez la section Exigences concernant les combinaisons de touches.
description
Chaîne utilisée pour fournir à l'utilisateur une brève description de l'objectif de la commande. Cette chaîne s'affiche dans l'interface utilisateur de gestion des raccourcis clavier de l'extension. Les descriptions sont obligatoires pour les commandes standards, mais elles sont ignorées pour les commandes d'action.
Une extension peut comporter de nombreuses commandes, mais ne peut pas spécifier plus de quatre raccourcis clavier suggérés. L'utilisateur peut ajouter manuellement d'autres raccourcis à partir de la boîte de dialogue chrome://extensions/shortcuts
.
Touches compatibles
Les touches suivantes sont des raccourcis de commande utilisables. Les définitions des clés sont sensibles à la casse. Toute tentative de chargement d'une extension avec une clé mal mise en majuscules génère une erreur d'analyse du fichier manifeste au moment de l'installation.
- Clés alpha
A
…Z
- Touches numériques
0
…9
- Chaînes de clés standards
Général :
Comma
,Period
,Home
,End
,PageUp
,PageDown
,Space
,Insert
,Delete
Touches fléchées :
Up
,Down
,Left
,Right
Touches multimédias :
MediaNextTrack
,MediaPlayPause
,MediaPrevTrack
,MediaStop
- Chaînes de touches de modification
Ctrl
,Alt
,Shift
,MacCtrl
(macOS uniquement),Command
(macOS uniquement),Search
(ChromeOS uniquement)
Exigences concernant les combinaisons de touches
Les raccourcis de commande d'extension doivent inclure
Ctrl
ouAlt
.Les modificateurs ne peuvent pas être utilisés avec les touches multimédias.
Sur de nombreux claviers macOS,
Alt
fait référence à la touche Option.Sous macOS, vous pouvez également utiliser
Command
ouMacCtrl
à la place deCtrl
ouAlt
(voir point suivant).
Sous macOS,
Ctrl
est automatiquement converti enCommand
.Command
peut également être utilisé dans le raccourci"mac"
pour faire référence explicitement à la touche Commande.Pour utiliser la touche Ctrl sous macOS, remplacez
Ctrl
parMacCtrl
lorsque vous définissez le raccourci"mac"
.L'utilisation de
MacCtrl
dans la combinaison pour une autre plate-forme entraînera une erreur de validation et empêchera l'installation de l'extension.
Shift
est un modificateur facultatif sur toutes les plates-formes.Search
est un modificateur facultatif exclusif à ChromeOS.Certains raccourcis du système d'exploitation et de Chrome (par exemple, la gestion des fenêtres) ont toujours la priorité sur les raccourcis de commande des extensions et ne peuvent pas être ignorés.
Gérer les événements de commande
manifest.json:
{
"name": "My extension",
...
"commands": {
"run-foo": {
"suggested_key": {
"default": "Ctrl+Shift+Y",
"mac": "Command+Shift+Y"
},
"description": "Run \"foo\" on the current page."
},
"_execute_action": {
"suggested_key": {
"windows": "Ctrl+Shift+Y",
"mac": "Command+Shift+Y",
"chromeos": "Ctrl+Shift+U",
"linux": "Ctrl+Shift+J"
}
}
},
...
}
Dans votre service worker, vous pouvez lier un gestionnaire à chacune des commandes définies dans le fichier manifeste à l'aide de onCommand.addListener
. Exemple :
service-worker.js :
chrome.commands.onCommand.addListener((command) => {
console.log(`Command: ${command}`);
});
Commandes d'action
Les commandes _execute_action
(Manifest V3), _execute_browser_action
(Manifest V2) et _execute_page_action
(Manifest V2) sont réservées à l'action de déclencher votre action, votre action dans le navigateur ou votre action sur la page, respectivement. Ces commandes n'envoient pas d'événements command.onCommand comme les commandes standards.
Si vous devez prendre une mesure en fonction de l'ouverture de votre pop-up, envisagez d'écouter un événement DOMContentLoaded dans le code JavaScript de votre pop-up.
Portée
Par défaut, les commandes sont limitées au navigateur Chrome. Cela signifie que lorsque le navigateur n'est pas actif, les raccourcis de commande sont inactifs. À partir de Chrome 35, les développeurs d'extensions peuvent éventuellement marquer une commande comme "globale". Les commandes globales fonctionnent également lorsque Chrome n'est pas sélectionné.
Les suggestions de raccourcis clavier pour les commandes globales sont limitées à Ctrl+Shift+[0..9]
. Il s'agit d'une mesure de protection visant à réduire le risque de forçage des raccourcis dans d'autres applications. En effet, si Alt+P
était autorisé en tant que global, le raccourci clavier permettant d'ouvrir une boîte de dialogue d'impression risquerait de ne pas fonctionner dans d'autres applications.
Les utilisateurs finaux sont libres de remapper les commandes globales sur leur combinaison de touches préférée à l'aide de l'UI exposée à chrome://extensions/shortcuts
.
Exemple :
manifest.json:
{
"name": "My extension",
...
"commands": {
"toggle-feature-foo": {
"suggested_key": {
"default": "Ctrl+Shift+5"
},
"description": "Toggle feature foo",
"global": true
}
},
...
}
Exemples
Les exemples suivants exploitent les fonctionnalités de base de l'API Commands.
Commande de base
Les commandes permettent aux extensions de mapper la logique à des raccourcis clavier que l'utilisateur peut appeler. Dans sa forme la plus simple, une commande ne nécessite qu'une déclaration de commande dans le fichier manifeste de l'extension et un enregistrement d'écouteur, comme illustré dans l'exemple suivant.
manifest.json:
{
"name": "Command demo - basic",
"version": "1.0",
"manifest_version": 3,
"background": {
"service_worker": "service-worker.js"
},
"commands": {
"inject-script": {
"suggested_key": "Ctrl+Shift+Y",
"description": "Inject a script on the page"
}
}
}
service-worker.js :
chrome.commands.onCommand.addListener((command) => {
console.log(`Command "${command}" triggered`);
});
Commande d'action
Comme décrit dans la section Concepts et utilisation, vous pouvez également mapper une commande à l'action d'une extension. L'exemple suivant injecte un script de contenu qui affiche une alerte sur la page en cours lorsque l'utilisateur clique sur l'action de l'extension ou déclenche le raccourci clavier.
manifest.json:
{
"name": "Commands demo - action invocation",
"version": "1.0",
"manifest_version": 3,
"background": {
"service_worker": "service-worker.js"
},
"permissions": ["activeTab", "scripting"],
"action": {},
"commands": {
"_execute_action": {
"suggested_key": {
"default": "Ctrl+U",
"mac": "Command+U"
}
}
}
}
service-worker.js :
chrome.action.onClicked.addListener((tab) => {
chrome.scripting.executeScript({
target: {tabId: tab.id},
func: contentScriptFunc,
args: ['action'],
});
});
function contentScriptFunc(name) {
alert(`"${name}" executed`);
}
// This callback WILL NOT be called for "_execute_action"
chrome.commands.onCommand.addListener((command) => {
console.log(`Command "${command}" called`);
});
Vérifier les commandes enregistrées
Si une extension tente d'enregistrer un raccourci déjà utilisé par une autre extension, le raccourci de la deuxième extension ne s'enregistrera pas comme prévu. Vous pouvez offrir une expérience utilisateur plus robuste en anticipant cette possibilité et en vérifiant les collisions au moment de l'installation.
service-worker.js :
chrome.runtime.onInstalled.addListener((details) => {
if (details.reason === chrome.runtime.OnInstalledReason.INSTALL) {
checkCommandShortcuts();
}
});
// Only use this function during the initial install phase. After
// installation the user may have intentionally unassigned commands.
function checkCommandShortcuts() {
chrome.commands.getAll((commands) => {
let missingShortcuts = [];
for (let {name, shortcut} of commands) {
if (shortcut === '') {
missingShortcuts.push(name);
}
}
if (missingShortcuts.length > 0) {
// Update the extension UI to inform the user that one or more
// commands are currently unassigned.
}
});
}
Types
Command
Propriétés
-
description
chaîne facultatif
Description de la commande d'extension
-
nom
chaîne facultatif
Nom de la commande d'extension
-
raccourci
chaîne facultatif
Raccourci actif pour cette commande, ou vide s'il n'est pas actif.
Méthodes
getAll()
chrome.commands.getAll(
callback?: function,
)
Renvoie toutes les commandes d'extension enregistrées pour cette extension et leur raccourci (s'il est actif). Avant Chrome 110, cette commande ne renvoyait pas _execute_action
.
Paramètres
Renvoie
-
Promise<Command[]>
Chrome 96 ou version ultérieureLes promesses sont compatibles avec la version 3 du fichier manifeste et les versions ultérieures, mais des rappels sont fournis pour assurer la rétrocompatibilité. Vous ne pouvez pas utiliser les deux dans le même appel de fonction. La promesse se résout avec le même type que celui transmis au rappel.
Événements
onCommand
chrome.commands.onCommand.addListener(
callback: function,
)
Déclenché lorsqu'une commande enregistrée est activée à l'aide d'un raccourci clavier.