Rendi l'app installabile

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

È inoltre presente un pulsante di installazione nascosto per impostazione predefinita.

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

La cattura dell'evento consente agli sviluppatori di personalizzare l'installazione e di chiedere all'utente di eseguire l'installazione quando ritiene 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; ce ne servirà più tardi 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() sull'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 di installazione.
  2. Chiama prompt() nell'evento beforeinstallprompt salvato.
  3. Registra i risultati del prompt.
  4. Imposta l'evento beforeinstallprompt salvato su null.
  5. Nascondere 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

L'installazione di un'app web tramite un pulsante di installazione è solo uno dei modi in cui gli utenti possono installarla. Possono anche utilizzare il menu di Chrome, la mini barra delle informazioni e tramite un'icona nell'omnibox. Puoi monitorare tutti questi modi di installazione ascoltando l'evento appinstalled.

  1. Aggiungi un gestore di eventi appinstalled all'oggetto window.
  2. Registra l'evento di installazione in Analytics 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, ora puoi installare la tua app.

Ecco alcune altre cose che puoi fare: