Update service-worker.js
Browse files- service-worker.js +21 -10
service-worker.js
CHANGED
|
@@ -40,19 +40,14 @@ self.addEventListener('activate', (event) => {
|
|
| 40 |
self.addEventListener('fetch', (event) => {
|
| 41 |
const requestUrl = new URL(event.request.url);
|
| 42 |
|
| 43 |
-
// Пропускаем запросы к внешнему iframe
|
| 44 |
if (requestUrl.origin !== self.location.origin) {
|
| 45 |
-
console.log('Пропускаем внешний
|
| 46 |
-
|
| 47 |
-
fetch(event.request).catch((error) => {
|
| 48 |
-
console.error('Ошибка при внешнем запросе:', error);
|
| 49 |
-
return new Response('Network error occurred', { status: 503 });
|
| 50 |
-
})
|
| 51 |
-
);
|
| 52 |
return;
|
| 53 |
}
|
| 54 |
|
| 55 |
-
// Для навигационных запросов
|
| 56 |
if (event.request.mode === 'navigate') {
|
| 57 |
event.respondWith(
|
| 58 |
caches.match('/index.html').then((response) => {
|
|
@@ -63,15 +58,31 @@ self.addEventListener('fetch', (event) => {
|
|
| 63 |
// Для локальных ресурсов используем Cache First
|
| 64 |
event.respondWith(
|
| 65 |
caches.match(event.request).then((response) => {
|
| 66 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 67 |
if (requestUrl.origin === self.location.origin) {
|
| 68 |
return caches.open(CACHE_NAME).then((cache) => {
|
| 69 |
cache.put(event.request, networkResponse.clone());
|
| 70 |
return networkResponse;
|
| 71 |
});
|
| 72 |
}
|
|
|
|
| 73 |
return networkResponse;
|
| 74 |
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 75 |
})
|
| 76 |
);
|
| 77 |
}
|
|
|
|
| 40 |
self.addEventListener('fetch', (event) => {
|
| 41 |
const requestUrl = new URL(event.request.url);
|
| 42 |
|
| 43 |
+
// Пропускаем запросы к внешнему iframe. Кэшируем их стандартным образом браузера.
|
| 44 |
if (requestUrl.origin !== self.location.origin) {
|
| 45 |
+
console.log('Пропускаем внешний запрос (не кэшируем через SW):', requestUrl.href);
|
| 46 |
+
// Используем стандартный fetch, не вмешиваясь. Браузер сам разберется с кэшированием.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 47 |
return;
|
| 48 |
}
|
| 49 |
|
| 50 |
+
// Для навигационных запросов (это запросы к index.html)
|
| 51 |
if (event.request.mode === 'navigate') {
|
| 52 |
event.respondWith(
|
| 53 |
caches.match('/index.html').then((response) => {
|
|
|
|
| 58 |
// Для локальных ресурсов используем Cache First
|
| 59 |
event.respondWith(
|
| 60 |
caches.match(event.request).then((response) => {
|
| 61 |
+
// Возвращаем кэшированный ресурс, если есть.
|
| 62 |
+
if (response) {
|
| 63 |
+
return response;
|
| 64 |
+
}
|
| 65 |
+
|
| 66 |
+
// Если ресурса нет в кэше, делаем сетевой запрос.
|
| 67 |
+
return fetch(event.request).then((networkResponse) => {
|
| 68 |
+
// Если запрос с нашего origin, кэшируем ответ.
|
| 69 |
if (requestUrl.origin === self.location.origin) {
|
| 70 |
return caches.open(CACHE_NAME).then((cache) => {
|
| 71 |
cache.put(event.request, networkResponse.clone());
|
| 72 |
return networkResponse;
|
| 73 |
});
|
| 74 |
}
|
| 75 |
+
// Если запрос не с нашего origin, просто возвращаем ответ (не кэшируем в SW).
|
| 76 |
return networkResponse;
|
| 77 |
});
|
| 78 |
+
}).catch(error => {
|
| 79 |
+
// Обработка ошибок, если и кэш недоступен, и сеть.
|
| 80 |
+
console.error("Fetch failed:", error);
|
| 81 |
+
// Можно вернуть страницу-заглушку об ошибке.
|
| 82 |
+
return new Response('<h1>Offline</h1><p>Sorry, the content is not available offline.</p>', {
|
| 83 |
+
headers: { 'Content-Type': 'text/html' }
|
| 84 |
+
});
|
| 85 |
+
|
| 86 |
})
|
| 87 |
);
|
| 88 |
}
|