Skip to content

Instantly share code, notes, and snippets.

@npofopr
Forked from ireade/sw.js
Created December 29, 2018 08:06
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save npofopr/8c50ac8b0a2d071e4d8468c686567426 to your computer and use it in GitHub Desktop.
Save npofopr/8c50ac8b0a2d071e4d8468c686567426 to your computer and use it in GitHub Desktop.
Handle broken images with the service worker
self.addEventListener('install', (e) => {
e.waitUntil(
caches.open("precache").then((cache) => cache.add("/broken.png"))
);
});
function isImage(fetchRequest) {
return fetchRequest.method === "GET" && fetchRequest.destination === "image";
}
self.addEventListener('fetch', (e) => {
e.respondWith(
fetch(e.request)
.then((response) => {
if (response.ok) return response;
// User is online, but response was not ok
if (isImage(e.request)) {
// Get broken image placeholder from cache
return caches.match("/broken.png");
}
})
.catch((err) => {
// User is probably offline
if (isImage(e.request)) {
// Get broken image placeholder from cache
return caches.match("/broken.png");
}
}) // end fetch
)
});
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment