What is a service worker?
A tip for Chrome users: to see what service workers are currently running in your browser, open Developer Tools (F12), click "Application" on the top bar, and click "Service Workers" on the sidebar that comes up.
How a service worker works
A service worker has three steps in its lifecycle:
Once these three steps are finished, the service worker stays in the browser indefinitely, even if the user refreshes the page, making it useful for storing information in the cache to be used offline. Read more on the service worker lifecycle here.
Here is a guide from Google detailing the code you need to set up a service worker.
Using service workers for version management
Each time a page is refreshed, the service worker file is checked for any changes. If even a byte has changed, a new service worker is loaded, ready to place the old one whenever the
skipWaiting event is triggered. We can take advantage of this fact by changing the service worker file in each new version of the app.
Typically, the top of a service worker file will have something like the following variable declaration: const CACHE_NAME = 'my-site-static-v1';
Each time you create a new version of the app, just update the service worker script, changing 'v1' to whatever the new version is (e.g., 'v4.5.2') and a new service worker will be created automatically.
Note: if you happen to be using
grunt for build tasks, make sure to use
grunt-text-replace to replace the version number (installation instructions for grunt-text-replace), as
grunt-text-replace supports in-place overwriting, which means you can directly edit the source file for your service worker. All of the other text-replace modules I found for grunt only allow editing in the build files.
Fetching the new service workers
Now that you have a new service worker for each new version of the app, the user should be prompted to fetch the new version. This involves triggering the
skipWaiting event on a service worker and reloading the page. A working implementation of this feature can be found here.
Service workers are not easy to deal with, but they can enable effective version management with offline web apps. This tutorial represents just one of the many ways version management can be implemented in an offline web app.