chrome.alarms

Descrizione

Utilizza l'API chrome.alarms per pianificare l'esecuzione del codice periodicamente o in un momento specifico in futuro.

Autorizzazioni

alarms

Manifest

Per utilizzare l'API chrome.alarms, dichiara l'autorizzazione "alarms" nel manifest:

{
  "name": "My extension",
  ...
  "permissions": [
    "alarms"
  ],
  ...
}

Esempi

Gli esempi seguenti mostrano come utilizzare e rispondere a un allarme. Per provare questa API, installa l'esempio di API Alarm dal repository chrome-extension-samples.

Imposta una sveglia

Il seguente esempio imposta una sveglia nel service worker quando l'estensione viene installata:

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
  });
});

Rispondere a un allarme

L'esempio seguente imposta l'icona della barra degli strumenti delle azioni in base al nome dell'allarme attivato.

service-worker.js:

chrome.alarms.onAlarm.addListener((alarm) => {
  chrome.action.setIcon({
    path: getIconPath(alarm.name),
  });
});

Tipi

Alarm

Proprietà

  • nome

    stringa

    Il nome di questa sveglia.

  • periodInMinutes

    number (facoltativo)

    Se non è nullo, la sveglia è ripetuta e suonerà di nuovo tra periodInMinutes minuti.

  • scheduledTime

    numero

    Ora in cui è stata pianificata l'attivazione di questo allarme, in millisecondi trascorsi dall'epoca (ad es. Date.now() + n). Per motivi di prestazioni, l'allarme potrebbe essere stato ritardato di un intervallo di tempo arbitrario.

AlarmCreateInfo

Proprietà

  • delayInMinutes

    number (facoltativo)

    Durata in minuti dopo la quale deve essere attivato l'evento onAlarm.

  • periodInMinutes

    number (facoltativo)

    Se impostato, l'evento onAlarm deve essere attivato ogni periodInMinutes minuti dopo l'evento iniziale specificato da when o delayInMinutes. Se non viene impostato, l'allarme si attiverà una sola volta.

  • quando

    number (facoltativo)

    Ora in cui deve scattare l'allarme, in millisecondi dopo l'epoca (ad es. Date.now() + n).

Metodi

clear()

Promessa
chrome.alarms.clear(
  name?: string,
  callback?: function,
)
: Promise<boolean>

Cancella la sveglia con il nome specificato.

Parametri

  • nome

    stringa facoltativa

    Il nome dell'allarme da cancellare. Il valore predefinito è la stringa vuota.

  • callback

    funzione facoltativa

    Il parametro callback ha il seguente aspetto:

    (wasCleared: boolean) => void

    • wasCleared

      booleano

Resi

  • Promise<boolean>

    Chrome 91+

    Le promesse sono supportate solo per Manifest V3 e versioni successive, le altre piattaforme devono utilizzare i callback.

clearAll()

Promessa
chrome.alarms.clearAll(
  callback?: function,
)
: Promise<boolean>

Cancella tutte le sveglie.

Parametri

  • callback

    funzione facoltativa

    Il parametro callback ha il seguente aspetto:

    (wasCleared: boolean) => void

    • wasCleared

      booleano

Resi

  • Promise<boolean>

    Chrome 91+

    Le promesse sono supportate solo per Manifest V3 e versioni successive, le altre piattaforme devono utilizzare i callback.

create()

Promessa
chrome.alarms.create(
  name?: string,
  alarmInfo: AlarmCreateInfo,
  callback?: function,
)
: Promise<void>

Crea una sveglia. In prossimità dell'ora o delle ore specificate da alarmInfo, viene attivato l'evento onAlarm. Se esiste un'altra sveglia con lo stesso nome (o senza nome se non ne è stato specificato uno), verrà annullata e sostituita da questa sveglia.

Per ridurre il carico sulla macchina dell'utente, Chrome limita gli allarmi a un massimo di una volta ogni 30 secondi, ma può ritardarli di un ulteriore periodo di tempo arbitrario. ovvero l'impostazione di delayInMinutes o periodInMinutes su un valore inferiore a 0.5 non verrà rispettata e verrà visualizzato un avviso. when può essere impostato su un valore inferiore a 30 secondi dopo "ora" senza avviso, ma non attiverà la sveglia per almeno 30 secondi.

Per aiutarti a eseguire il debug dell'app o dell'estensione, una volta caricata decompressa, non esiste un limite alla frequenza con cui può attivarsi l'allarme.

Parametri

  • nome

    stringa facoltativa

    Nome facoltativo per identificare questo allarme. Il valore predefinito è la stringa vuota.

  • alarmInfo

    Descrive quando deve attivarsi l'allarme. L'ora iniziale deve essere specificata da when o delayInMinutes (ma non entrambi). Se periodInMinutes è impostato, l'allarme si ripeterà ogni periodInMinutes minuti dopo l'evento iniziale. Se non viene impostato né whendelayInMinutes per una sveglia ripetuta, periodInMinutes viene utilizzato come valore predefinito per delayInMinutes.

  • callback

    funzione facoltativa

    Chrome 111+

    Il parametro callback ha il seguente aspetto:

    () => void

Resi

  • Promise<void>

    Chrome 111+

    Le promesse sono supportate solo per Manifest V3 e versioni successive, le altre piattaforme devono utilizzare i callback.

get()

Promessa
chrome.alarms.get(
  name?: string,
  callback?: function,
)
: Promise<Alarm | undefined>

Recupera i dettagli della sveglia specificata.

Parametri

  • nome

    stringa facoltativa

    Il nome della sveglia da ottenere. Il valore predefinito è la stringa vuota.

  • callback

    funzione facoltativa

    Il parametro callback ha il seguente aspetto:

    (alarm?: Alarm) => void

Resi

  • Promise<Alarm | undefined>

    Chrome 91+

    Le promesse sono supportate solo per Manifest V3 e versioni successive, le altre piattaforme devono utilizzare i callback.

getAll()

Promessa
chrome.alarms.getAll(
  callback?: function,
)
: Promise<Alarm[]>

Restituisce un array di tutte le sveglie.

Parametri

  • callback

    funzione facoltativa

    Il parametro callback ha il seguente aspetto:

    (alarms: Alarm[]) => void

Resi

  • Promise<Alarm[]>

    Chrome 91+

    Le promesse sono supportate solo per Manifest V3 e versioni successive, le altre piattaforme devono utilizzare i callback.

Eventi

onAlarm

chrome.alarms.onAlarm.addListener(
  callback: function,
)

Attivato quando una sveglia è scaduta. Utile per le pagine degli eventi.

Parametri

  • callback

    funzione

    Il parametro callback ha il seguente aspetto:

    (alarm: Alarm) => void