Skip to content

Instantly share code, notes, and snippets.

@bradtraversy
Created August 2, 2018 20:50
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 4 You must be signed in to fork a gist
  • Save bradtraversy/cdbf04e6c6b0e37ed8c55620660556db to your computer and use it in GitHub Desktop.
Save bradtraversy/cdbf04e6c6b0e37ed8c55620660556db to your computer and use it in GitHub Desktop.
Service Worker To Cache Response
const cacheName = 'v2';
// Call Install Event
self.addEventListener('install', e => {
console.log('Service Worker: Installed');
});
// Call Activate Event
self.addEventListener('activate', e => {
console.log('Service Worker: Activated');
// Remove unwanted caches
e.waitUntil(
caches.keys().then(cacheNames => {
return Promise.all(
cacheNames.map(cache => {
if (cache !== cacheName) {
console.log('Service Worker: Clearing Old Cache');
return caches.delete(cache);
}
})
);
})
);
});
// Call Fetch Event
self.addEventListener('fetch', e => {
console.log('Service Worker: Fetching');
e.respondWith(
fetch(e.request)
.then(res => {
// Make copy/clone of response
const resClone = res.clone();
// Open cahce
caches.open(cacheName).then(cache => {
// Add response to cache
cache.put(e.request, resClone);
});
return res;
})
.catch(err => caches.match(e.request).then(res => res))
);
});
@CryceTruly
Copy link

Good work Brad

@tonymedrano
Copy link

Excellent! Thanks!

@JTorresConsulta
Copy link

Thanks for making it so easy !

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment