Пустая страница в автономном режиме

#javascript #reactjs #progressive-web-apps

#javascript #reactjs #progressive-веб-приложения

Вопрос:

Когда я перехожу в автономный режим, я могу видеть только пустую страницу. Я пытался удалить манифест из offline.html но это не сработало. Я думаю, что я написал что-то не так в offline.html . Но я не знаю, что. Помогите мне. Что я сделал не так?

https://thirsty-hopper-b0ad0a.netlify.app/

#serviceworker.js

 const CACHE_NAME = "version-1";
const urlsToCache = [ 'index.html', 'offline.html' ];

const self = this;

// Install SW
self.addEventListener('install', (event) => {
    event.waitUntil(
        caches.open(CACHE_NAME)
            .then((cache) => {
                console.log('Opened cache');

                return cache.addAll(urlsToCache);
            })
    )
});

// Listen for requests
self.addEventListener('fetch', (event) => {
    event.respondWith(
        caches.match(event.request)
            .then(() => {
                return fetch(event.request) 
                    .catch(() => caches.match('offline.html'))
            })
    )
});

// Activate the SW
self.addEventListener('activate', (event) => {
    const cacheWhitelist = [];
    cacheWhitelist.push(CACHE_NAME);

    event.waitUntil(
        caches.keys().then((cacheNames) => Promise.all(
            cacheNames.map((cacheName) => {
                if(!cacheWhitelist.includes(cacheName)) {
                    return caches.delete(cacheName);
                }
            })
        ))
            
    )
});  

#manifest.json

 {
  "short_name": "Pizza Joint",
  "name": "Pizza Joint",
  "icons": [
      {
      "src":"./icons/android-chrome-192x192.png",
      "sizes":"192x192",
      "type":"image/png"
  },{
      "src":"./icons/android-chrome-512x512.png",
      "sizes":"512x512",
      "type":"image/png"
  },{
      "src":"./icons/apple-touch-icon.png",
      "sizes":"180x180",
      "type":"image/png"
  },{
      "src":"./icons/favicon-16x16.png",
      "sizes":"16x16",
      "type":"image/png"
  },{
      "src":"./icons/favicon-32x32.png",
      "sizes":"32x32",
      "type":"image/png"
  }
  ],
  "start_url": "/",
  "display": "standalone",
  "theme_color": "#161616",
  "background_color": "#161616"
}  

#index.html

 <!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8" />
    <link rel="icon" href="./icons/favicon.ico" />
    <meta name="viewport" content="width=device-width, initial-scale=1" />
    <meta name="theme-color" content="#161616" />
    <meta name="description" content="Best app for ordering your favorite pizza" />
    <link rel="apple-touch-icon" href="./icons/apple-touch-icon.png" />
    <link rel="manifest" href="./manifest.json" />  

    <title>Pizza Joint</title>
  </head>
  <body>
    <noscript>You need to enable JavaScript to run this app.</noscript>
    <div id="root"></div>
    
    <script>
      if ('serviceWorker' in navigator) {
        window.addEventListener('load', () => {
          navigator.serviceWorker.register('./serviceworker.js')
            .then((reg) => console.log('Success: ', reg.scope))
            .catch((err) => console.log('Failure: ', err));
        });
      } else {
        console.log('Service Worker is not supported by browser.');
      }
    </script>
  </body>
</html>  

#offline.html

 <!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8" />
    <link rel="icon" href="./icons/favicon.ico" />
    <meta name="viewport" content="width=device-width, initial-scale=1" />
    <meta name="theme-color" content="#161616" />
    <meta name="description" content="Best app for ordering your favorite pizza" />
    <link rel="apple-touch-icon" href="./icons/apple-touch-icon.png" /> 
    
    <title>Pizza Joint</title>
  </head>
  <body>
    <noscript>You need to enable JavaScript to run this app.</noscript>
    <div id="root"></div>
   
    <script>
      if ('serviceWorker' in navigator) {
        window.addEventListener('load', () => {
          navigator.serviceWorker.register('./serviceworker.js')
            .then((reg) => console.log('Success: ', reg.scope))
            .catch((err) => console.log('Failure: ', err));
        });
      } else {
        console.log('Service Worker is not supported by browser.');
      }
    </script>
  </body>
</html>  

Комментарии:

1. репозиторий github github.com/Governnment/react

2. Вы тестируете на компьютере / устройстве, с которым вы тестировали во время разработки? Если это так, возможно, попробуйте на другом устройстве исключить что-то, что все еще находится в кэше браузера.

3. Я тестировал на своем мобильном телефоне, а затем на ПК. Я также очистил наличные везде. Я просто получаю пустую страницу. Несмотря ни на что. Возможно, у меня возникла проблема с offline.html шаблон. Я просто скопировал его с index.html . Не могли бы вы проверить мой код?

4. @Mathias Это сеть в Chrome [ссылка] ibb.co/PrDRPHV

5. Передается ли ваш PWA при запуске с URL-адресом HTTPS как действительный PWA с помощью инструмента Chrome Lighthouse? Если есть проблемы, это обычно дает хорошие подсказки. Похоже, есть некоторые проблемы, которые вам нужно исправить, чтобы сделать его действительным PWA. ( [ссылка]ibb.co/PrDRPHV )