A simple example using a Service Worker to cache resources from a React app.
- Window loading
- App rendering into the DOM
- App render a loading
- Service worker registration
- Service worker installation
- Prefetched resources into the cache
- Service worker activation
- Service worker installation
- App render the content
- Service worker intercept requests
- cache response if possible
- response from cache if necessary
This implementation is quite different from the others because I decided to register the service worker after the app initializes...and then delay it until the worker activated.
Unless that strategy the worker can't control the application immediately. First, because the app will start - and fetch resources - before the worker is activated. Also because a page will use a freshly registered worker from the next load unless a claim method is defined... during the worker activation.
That app architecture prevents both problems.
This project is online on this Github Page.
With Chrome browser you can open the Developer tools then open the Application tab.
Two entries are interesting there :
- Service workers will display workers currently registered and will allow you to set the page offline.
- Cache Storage will display created cache and resources stored inside.
Up to you to put the page offline then to reload it. Yeah, it's still working! \o/