Description
Utilisez l'API chrome.alarms pour planifier l'exécution de code à intervalles réguliers ou à une heure spécifiée.
Autorisations
alarmsFichier manifeste
Pour utiliser l'API chrome.alarms, déclarez l'autorisation "alarms" dans le fichier manifeste :
{
"name": "My extension",
...
"permissions": [
"alarms"
],
...
}
Exemples
Les exemples suivants montrent comment utiliser une alarme et y répondre. Pour essayer cette API, installez l'exemple d'API Alarm à partir du dépôt chrome-extension-samples.
Régler une alarme
L'exemple suivant définit une alarme dans le service worker lorsque l'extension est installée :
service-worker.js:
chrome.runtime.onInstalled.addListener(async ({ reason }) => {
if (reason !== 'install') {
return;
}
// Create an alarm so we have something to look at in the demo
await chrome.alarms.create('demo-default-alarm', {
delayInMinutes: 1,
periodInMinutes: 1
});
});
Répondre à une alarme
L'exemple suivant définit l'icône de la barre d'outils d'action action toolbar icon en fonction du nom de l'alarme qui s'est déclenchée.
service-worker.js:
chrome.alarms.onAlarm.addListener((alarm) => {
chrome.action.setIcon({
path: getIconPath(alarm.name),
});
});
Types
Alarm
Propriétés
-
nom
chaîne
Nom de cette alarme.
-
periodInMinutes
nombre facultatif
Si la valeur n'est pas nulle, l'alarme est répétée et se déclenchera à nouveau dans
periodInMinutesminutes. -
persistAcrossSessions
booléen
En attenteIndique si l'alarme doit persister d'une session à l'autre (redémarrage du navigateur).
-
scheduledTime
nombre
Heure à laquelle cette alarme a été programmée, en millisecondes depuis l'époque (par exemple,
Date.now() + n). Pour des raisons de performances, l'alarme peut avoir été retardée d'un montant arbitraire au-delà de cette valeur.
AlarmCreateInfo
Propriétés
-
delayInMinutes
nombre facultatif
Durée en minutes après laquelle l'événement
onAlarmdoit se déclencher. -
periodInMinutes
nombre facultatif
Si cette option est définie, l'événement onAlarm doit se déclencher toutes les
periodInMinutesminutes après l'événement initial spécifié parwhenoudelayInMinutes. Si cette option n'est pas définie, l'alarme ne se déclenchera qu'une seule fois. -
persistAcrossSessions
booléen facultatif
En attenteIndique si l'alarme doit persister d'une session à l'autre (redémarrage du navigateur). Dans Chrome, la valeur par défaut est "true" pour correspondre au comportement historique, mais vous devez la définir explicitement pour maximiser la compatibilité entre les navigateurs.
-
when
nombre facultatif
Heure à laquelle l'alarme doit se déclencher, en millisecondes depuis l'époque (par exemple,
Date.now() + n).
Méthodes
clear()
chrome.alarms.clear(
name?: string,
callback?: function,
): Promise<boolean>
Efface l'alarme portant le nom donné.
Paramètres
-
nom
chaîne facultative
Nom de l'alarme à effacer. La valeur par défaut est la chaîne vide.
-
callback
fonction facultative
Le paramètre
callbackse présente comme suit :(wasCleared: boolean) => void
-
wasCleared
booléen
-
Renvoie
-
Promise<boolean>
Chrome 91+Les promesses ne sont compatibles qu'avec Manifest V3 et versions ultérieures. Les autres plates-formes doivent utiliser des rappels.
clearAll()
chrome.alarms.clearAll(
callback?: function,
): Promise<boolean>
Efface toutes les alarmes.
Paramètres
-
callback
fonction facultative
Le paramètre
callbackse présente comme suit :(wasCleared: boolean) => void
-
wasCleared
booléen
-
Renvoie
-
Promise<boolean>
Chrome 91+Les promesses ne sont compatibles qu'avec Manifest V3 et versions ultérieures. Les autres plates-formes doivent utiliser des rappels.
create()
chrome.alarms.create(
name?: string,
alarmInfo: AlarmCreateInfo,
callback?: function,
): Promise<void>
Crée une alarme. L'événement onAlarm est déclenché à l'heure ou aux heures spécifiées par alarmInfo. S'il existe une autre alarme portant le même nom (ou sans nom si aucun n'est spécifié), elle est annulée et remplacée par cette alarme.
Afin de réduire la charge sur la machine de l'utilisateur, Chrome limite les alarmes à une fois toutes les 30 secondes au maximum, mais peut les retarder d'un montant arbitraire. Autrement dit, définir delayInMinutes ou periodInMinutes sur une valeur inférieure à 0.5 n'est pas autorisé et génère un avertissement. when peut être défini sur une valeur inférieure à 30 secondes après "now" sans avertissement, mais l'alarme ne se déclenchera pas avant au moins 30 secondes.
Pour vous aider à déboguer votre application ou votre extension, lorsque vous l'avez chargée non empaquetée, il n'y a pas de limite à la fréquence à laquelle l'alarme peut se déclencher.
Paramètres
-
nom
chaîne facultative
Nom facultatif permettant d'identifier cette alarme. La valeur par défaut est la chaîne vide.
-
alarmInfo
Décrit le moment où l'alarme doit se déclencher. L'heure initiale doit être spécifiée par
whenoudelayInMinutes(mais pas les deux). SiperiodInMinutesest défini, l'alarme se répète toutes lesperiodInMinutesminutes après l'événement initial. Si niwhen, nidelayInMinutesne sont définis pour une alarme répétée,periodInMinutesest utilisé comme valeur par défaut pourdelayInMinutes. -
callback
fonction facultative
Chrome 111+Le paramètre
callbackse présente comme suit :() => void
Renvoie
-
Promise<void>
Chrome 111+Promesse qui se résout lorsque l'alarme a été créée.
Les promesses ne sont compatibles qu'avec Manifest V3 et versions ultérieures. Les autres plates-formes doivent utiliser des rappels.
get()
chrome.alarms.get(
name?: string,
callback?: function,
): Promise<Alarm | undefined>
Récupère des informations sur l'alarme spécifiée.
Paramètres
Renvoie
-
Promise<Alarm | undefined>
Chrome 91+Les promesses ne sont compatibles qu'avec Manifest V3 et versions ultérieures. Les autres plates-formes doivent utiliser des rappels.
getAll()
chrome.alarms.getAll(
callback?: function,
): Promise<Alarm[]>
Récupère un tableau de toutes les alarmes.
Paramètres
Renvoie
-
Promise<Alarm[]>
Chrome 91+Les promesses ne sont compatibles qu'avec Manifest V3 et versions ultérieures. Les autres plates-formes doivent utiliser des rappels.