Better service-worker cache-handling
This commit is contained in:
@@ -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;
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user