Better service-worker cache-handling

This commit is contained in:
Kasper Rynning-Tønnesen
2020-01-28 15:49:25 +01:00
parent 59af85bbd1
commit 3975e5d7f2

View File

@@ -20,7 +20,7 @@ self.addEventListener("activate", event => {
}); });
self.addEventListener("install", event => { self.addEventListener("install", event => {
console.log("Service Worker installing."); console.log("Arbeids arbeideren installerer seg.");
event.waitUntil( event.waitUntil(
caches.open(CACHE_NAME).then(cache => cache.addAll(STATIC_CACHE_URLS)) caches.open(CACHE_NAME).then(cache => cache.addAll(STATIC_CACHE_URLS))
); );
@@ -28,25 +28,22 @@ self.addEventListener("install", event => {
self.addEventListener("fetch", event => { self.addEventListener("fetch", event => {
event.respondWith( event.respondWith(
fetch(event.request).catch(function() {
return caches.match(event.request);
})
);
event.waitUntil(
fetch(event.request) fetch(event.request)
.then(function(response) { .then(response => cache(event.request, response))
cache(event.request, response); .catch(function() {
return caches.match(event.request);
}) })
.catch(error => {})
); );
}); });
function cache(request, response) { function cache(request, response) {
//console.log(response.type === "error" || response.type === "opaque", request);
if (response.type === "error" || response.type === "opaque") { if (response.type === "error" || response.type === "opaque") {
return Promise.resolve(); // do not put in cache network errors return response;
} }
return caches return caches.open(CACHE_NAME).then(cache => {
.open(CACHE_NAME) cache.put(request, response.clone());
.then(cache => cache.put(request, response.clone())); return response;
});
} }