Rendi l'app installabile

Questo glitch contiene il manifest web con i campi obbligatori per rendere un'app web installabile.

Ha anche un pulsante di installazione nascosto per impostazione predefinita.

Ascolta l'evento beforeinstallprompt

Quando il browser attiva l'evento beforeinstallprompt, questo indica che l'app web può essere installata e che è possibile mostrare all'utente un pulsante di installazione. L'evento beforeinstallprompt viene attivato quando l'app soddisfa i criteri di installazione.

L'acquisizione dell'evento consente agli sviluppatori di personalizzare l'installazione e chiedere all'utente di farlo quando ritengono che sia il momento migliore.

  1. Fai clic su Remix per modificare per rendere il progetto modificabile.
  2. Aggiungi un gestore di eventi beforeinstallprompt all'oggetto window.
  3. Salva event come variabile globale. Ci servirà in un secondo momento per mostrare il prompt.
  4. Mostra il pulsante di installazione.

Codice:

window.addEventListener('beforeinstallprompt', (event) => {
  // Prevent the mini-infobar from appearing on mobile.
  event.preventDefault();
  console.log('👍', 'beforeinstallprompt', event);
  // Stash the event so it can be triggered later.
  window.deferredPrompt = event;
  // Remove the 'hidden' class from the install button container.
  divInstall.classList.toggle('hidden', false);
});

Gestire il clic sul pulsante di installazione

Per mostrare la richiesta di installazione, chiama prompt() nell'evento beforeinstallprompt salvato. La chiamata a prompt() viene eseguita nel gestore dei clic del pulsante di installazione perché prompt() deve essere chiamato da un gesto dell'utente.

  1. Aggiungi un gestore di eventi di clic per il pulsante Installa.
  2. Chiama prompt() sull'evento beforeinstallprompt salvato.
  3. Registra i risultati del prompt.
  4. Imposta l'evento beforeinstallprompt salvato su null.
  5. Nascondi il pulsante di installazione.

Codice:

butInstall.addEventListener('click', async () => {
  console.log('👍', 'butInstall-clicked');
  const promptEvent = window.deferredPrompt;
  if (!promptEvent) {
    // The deferred prompt isn't available.
    return;
  }
  // Show the install prompt.
  promptEvent.prompt();
  // Log the result
  const result = await promptEvent.userChoice;
  console.log('👍', 'userChoice', result);
  // Reset the deferred prompt variable, since
  // prompt() can only be called once.
  window.deferredPrompt = null;
  // Hide the install button.
  divInstall.classList.toggle('hidden', true);
});

Monitorare l'evento di installazione

Installare un'app web tramite un pulsante di installazione è solo uno dei modi in cui gli utenti possono installarla. Gli utenti possono anche usare il menu di Chrome, la mini-barra delle informazioni e tramite un'icona nella omnibox. Puoi monitorare tutte queste modalità di installazione ascoltando l'evento appinstalled.

  1. Aggiungi un gestore di eventi appinstalled all'oggetto window.
  2. Registra l'evento di installazione in analisi o in un altro meccanismo.

Codice:

window.addEventListener('appinstalled', (event) => {
  console.log('👍', 'appinstalled', event);
  // Clear the deferredPrompt so it can be garbage collected
  window.deferredPrompt = null;
});

Per approfondire

Congratulazioni, la tua app è ora installabile.

Di seguito sono riportate altre operazioni che puoi eseguire: