Я пытаюсь, чтобы мой PWA отвечал страницей offline.html, когда устройство находится в автономном режиме, и я рассматриваю ошибку при извлечении домашней страницы как офлайн, но, поскольку мой работник службы кэширует запросы text / html, мой PWA использует кэш для выборки домашней страницы каждый развремя.
Я использую workbox для генерации моего PWA, и я попытался удалить документ из файла workbox-config.js.
Код
workbox-config.js
module.exports = {
globDirectory: 'build/',
globPatterns: [
'**/*.{png,ico,css,js}',
],
swDest: 'build\\sw.js',
swSrc: 'src/sw.js',
injectionPointRegexp: /(const precacheManifest = )\[\](;)/,
};
Обработчик получения в сервисном работнике
self.addEventListener('fetch', (event) => {
console.log('fetch event', event.request.url);
// request.mode = navigate isn't supported in all browsers
// so include a check for Accept: text/html header.
// if (event.request.method === 'GET') {
// console.log(event.request.url, event.request.headers.get('accept'));
// }
if (event.request.mode === 'navigate' || (event.request.method === 'GET' && event.request.headers.get('accept').includes('text/html'))) {
event.respondWith(
fetch(event.request.url).catch((error) => {
console.log(123, error);
// Return the offline page
return caches.match('/offline.html');
}),
);
}
else {
event.respondWith(
caches.match(event.request)
.then((response) => {
if (response) {
console.log('Found ', event.request.url, ' in cache');
return response;
}
return fetch(event.request);
}),
);
}
});
Я ожидаю, что мой PWA будет каждый раз получать домашнюю страницу с моего сервера, но вместо этого я получаю это.
вот URL: https://smartcopy -195fd.firebaseapp.com