From c0a03c32712d85a30f3d704a59054bc8c2ad478a Mon Sep 17 00:00:00 2001 From: arun Date: Sun, 24 May 2020 21:39:35 +0530 Subject: [PATCH] Add cache strategy with cacheFirst and networkFirst --- serviceWorker.js | 60 ++++++++++++++++++++++++++---------------------- 1 file changed, 33 insertions(+), 27 deletions(-) diff --git a/serviceWorker.js b/serviceWorker.js index 21a6d65..734bdab 100644 --- a/serviceWorker.js +++ b/serviceWorker.js @@ -54,36 +54,42 @@ self.addEventListener('fetch', (event) => { console.info('Event: Fetch'); var request = event.request; + var url = new URL(request.url); + if (url.origin === location.origin) { + // Static files cache + event.respondWith(cacheFirst(request)); + } else { + // Dynamic API cache + event.respondWith(networkFirst(request)); + } - //Tell the browser to wait for newtwork request and respond with below - event.respondWith( - //If request is already in cache, return it - caches.match(request).then((response) => { - if (response) { - return response; - } - - // // Checking for navigation preload response - // if (event.preloadResponse) { - // console.info('Using navigation preload'); - // return response; - // } - - //if request is not cached or navigation preload response, add it to cache - return fetch(request).then((response) => { - var responseToCache = response.clone(); - caches.open(cacheName).then((cache) => { - cache.put(request, responseToCache).catch((err) => { - console.warn(request.url + ': ' + err.message); - }); - }); - - return response; - }); - }) - ); + // // Checking for navigation preload response + // if (event.preloadResponse) { + // console.info('Using navigation preload'); + // return response; + // } }); +async function cacheFirst(request) { + const cachedResponse = await caches.match(request); + return cachedResponse || fetch(request); +} + +async function networkFirst(request) { + const dynamicCache = await caches.open(cacheName); + try { + const networkResponse = await fetch(request); + // Cache the dynamic API response + dynamicCache.put(request, networkResponse.clone()).catch((err) => { + console.warn(request.url + ': ' + err.message); + }); + return networkResponse; + } catch (err) { + const cachedResponse = await dynamicCache.match(request); + return cachedResponse; + } +} + /* ACTIVATE EVENT: triggered once after registering, also used to clean up caches. */