DevGang
Авторизоваться

Запуск всплывающего окна «Add To Home Screen» при нажатии кнопки

В предыдущем разделе мы узнали, как создать прогрессивное веб-приложение с автоматическим запросом «Add To Home Screen» при загрузке страницы. Однако в некоторых случаях вам может понадобиться больше контроля над тем, когда отображать всплывающее окно «Add To Home Screen». В этом разделе мы рассмотрим, как добавить кнопку «Установить приложение», которая при нажатии вызывает всплывающее окно «Add To Home Screen», предоставляя пользователям возможность установить приложение в удобное для них время.

Шаг 1. Добавьте кнопку «Install App».

В index.html добавьте элемент кнопки с идентификатором «install-btn», который будет служить триггером для всплывающего окна «Добавить на главный экран». Кнопку можно разместить там, где вы хотите, чтобы она отображалась в интерфейсе вашего веб-приложения.

<!DOCTYPE html>
<html>
<head>
  <!-- ... (Other meta tags and links) ... -->
  <link rel="manifest" href="manifest.json">
  <!-- ... (Other styles) ... -->
</head>
<body>
  <!-- ... (Your web app content) ... -->

  <!-- Add the "Install App" button -->
  <button id="install-btn" style="display: none;">Install App</button>

  <script>
    // Your JavaScript code will go here
  </script>
</body>
</html>

Шаг 2: Реализуйте функцию JavaScript

Затем нам нужно реализовать функцию JavaScript, которая будет обрабатывать нажатие кнопки «Install App» и вызывать всплывающее окно «Add To Home screen».

<script>
  // Check if the browser supports the beforeinstallprompt event
  if ('serviceWorker' in navigator && 'BeforeInstallPromptEvent' in window) {
    // Listen for the beforeinstallprompt event
    window.addEventListener('beforeinstallprompt', (event) => {
      // Prevent the default "Add to Home Screen" prompt
      event.preventDefault();

      // Show the "Install App" button
      const installButton = document.getElementById('install-btn');
      installButton.style.display = 'block';

      // Save the event for later use
      let deferredPrompt = event;

      // Add event listener to the "Install App" button
      installButton.addEventListener('click', () => {
        // Trigger the "Add to Home Screen" prompt
        deferredPrompt.prompt();

        // Wait for the user to respond to the prompt
        deferredPrompt.userChoice
          .then((choiceResult) => {
            // Reset the prompt variable
            deferredPrompt = null;
            // Hide the "Install App" button after the prompt is shown
            installButton.style.display = 'none';
          });
      });
    });
  }
</script>

В этом коде JavaScript мы проверяем, поддерживает ли браузер событие beforeinstallprompt. Если это так, мы прослушиваем событие и сохраняем его в переменной deferredPrompt. Когда нажимается кнопка «Install App», мы вызываем метод prompt() для сохраненного события, вызывая приглашение «Add To Home Screen». После того, как пользователь ответит на запрос, мы скроем кнопку «Install App».

Шаг 3. Тестирование и развертывание

Протестируйте свое прогрессивное веб-приложение, чтобы убедиться, что кнопка «Install App» правильно вызывает всплывающее окно «Add To Home Screen». Как только вы будете удовлетворены функциональностью, разверните обновленное PWA на своем действующем веб-сайте.

Заключение:

Добавляя кнопку «Установить приложение», которая вызывает всплывающее окно «Добавить на главный экран» при нажатии кнопки, вы предоставляете пользователям возможность решать, когда они хотят установить ваше веб-приложение. Такой подход дает пользователям больший контроль над процессом установки и поощряет участие. Благодаря возможностям PWA и продуманной реализации вы можете создать удобный интерфейс, способный конкурировать с нативными приложениями, и в то же время упростить пользователям доступ к вашему приложению со своих домашних экранов.

Источник:

#JavaScript
Комментарии
Чтобы оставить комментарий, необходимо авторизоваться