web.dev
Open in
urlscan Pro
2620:0:890::100
Public Scan
URL:
https://web.dev/learn/pwa/service-workers/
Submission: On September 14 via manual from DE — Scanned from DE
Submission: On September 14 via manual from DE — Scanned from DE
Form analysis
0 forms found in the DOMText Content
web.dev uses cookies to deliver and enhance the quality of its services and to analyze traffic. If you agree, cookies are also used to serve advertising and to personalize the content and advertisements that you see. Learn more. Agree No thanks Skip to main Open menu Learn PWA! Close * 000 Learn PWA * 001 Progressive Web Apps * 002 Getting started * 003 Foundations * 004 App design * 005 Assets and data * 006 Service workers * 007 Caching * 008 Serving * 009 Workbox * 010 Offline data * 011 Installation * 012 Web app manifest * 013 Installation prompt * 014 Update * 015 Enhancements * 016 Detection * 017 OS Integration * 018 Window management * 019 Experimental features * 020 Tools and debug * 021 Architecture * 022 Complexity management * 023 Capabilities * 024 Conclusion * * Learn * Learn PWA! Share On this page * Hello service workers * Registering a service worker * Verify if a service worker is registered * Scope * Lifecycle * Updating a service worker * Service worker lifespan * Capabilities * Resources 006 SERVICE WORKERS Service workers are a fundamental part of a PWA. They enable fast loading (regardless of the network), offline access, push notifications, and other capabilities. On this page * Hello service workers * Registering a service worker * Verify if a service worker is registered * Scope * Lifecycle * Updating a service worker * Service worker lifespan * Capabilities * Resources Users expect apps to start on slow or flaky network connections, or even when offline. They expect the content they've most recently interacted with, such as media tracks or tickets and itineraries, to be available and usable. When a request isn't possible, they expect the app to tell them instead of silently failing or crashing. And users wish to do it all quickly. As we can see in this study Milliseconds make millions, even a 0.1 second improvement in load times can improve conversion by up to 10%. In summary: users expect PWAs to be reliable and that's why we have service workers. HELLO SERVICE WORKERS # When an app requests a resource covered by the service worker's scope, including when a user is offline, the service worker intercepts the request, acting as a network proxy. It can then decide if it should serve the resource from the cache via the Cache Storage API, from the network as normally would happen without a service worker, or create it from a local algorithm. This lets you provide a similar experience to that provided by a platform app. It can even work entirely off line. Gotchas Not all browsers support service workers. Even when present your service worker won't be available on first load or while it's waiting to activate. Therefore, treat it as optional and do not require it for core functionality. REGISTERING A SERVICE WORKER # Before a service worker takes control of your page, it must be registered for your PWA. That means the first time a user comes to your PWA, network requests will not go directly to your server because the service worker is not yet in control of your pages. After checking if the browser supports the Service Worker API, your PWA can register a service worker. When loaded, the service worker sets up shop between your PWA and the network, intercepting requests and serving the corresponding responses. Copy code if ('serviceWorker' in navigator) { navigator.serviceWorker.register("/serviceworker.js"); } There is only one service worker per PWA, but that doesn't mean you need to place the code only in one file. A service worker can include other files using importScripts in every browser or using ECMAScript module imports in some modern browsers. VERIFY IF A SERVICE WORKER IS REGISTERED # To verify if a service worker is registered, use developer tools in your favorite browser. In Firefox and Chromium-based browsers (Microsoft Edge, Google Chrome, or Samsung Internet): 1. Open developer tools, then click the Application tab. 2. In the left pane, select Service Workers. 3. Check that the service worker's script URL appears with the status "Activated". (You'll learn what this status means in the lifecycle section in this chapter). On Firefox the status can be "Running" or "Stopped". In Safari: 1. Click the Develop menu then the Service Workers submenu. 2. Check that an entry with the current origin appears in the submenu. It opens an inspector over the service worker's context. Service worker developer tools on Chrome, Firefox and Safari. You can remotely inspect a phone or tablet from your desktop browser when you want to check service worker registration status on a mobile device. You will see details on how to do that in the Tools and Debug chapter SCOPE # The folder your service worker sits in determines its scope. A service worker that lives at example.com/my-pwa/sw.js can control any navigation at the my-pwa path or below, such as example.com/my-pwa/demos/. Service workers can only control items (pages, workers, collectively "clients") in their scope. Scope applies to browser tabs and PWA windows. Only one service worker per scope is allowed. When active and running, only one instance is typically available no matter how many clients are in memory (such as PWA windows or browser tabs). Warning You should set the scope of your service worker as close to the root of your app as possible. This is the most common setup as it lets the service worker intercept all the requests related to your PWA. Don't put it inside, for instance, a JavaScript folder or have it loaded from a CDN. Safari has more complex scope management, known as partitions, affecting how scopes work if you have cross-domain iframes. To read more about WebKit's implementation, read their blog post. LIFECYCLE # Service workers have a lifecycle that dictates how they are installed, this is separate from your PWA installation. The service worker lifecycle starts with registering the service worker. The browser then attempts to download and parse the service worker file. If parsing succeeds, its install event is fired. The install event only fires once. Service worker installation happens silently, without requiring user permission, even if the user doesn't install the PWA. The Service Worker API is even available on platforms that do not support PWA installation, such as Safari and Firefox on desktop devices. Gotchas Service worker registration and installation, while related, are different events. Registration happens when a page requests a service worker by calling register() as described previously. Installation happens when a registered service worker exists, can be parsed as JavaScript, and doesn't throw any errors during its first execution. After the installation, the service worker is not yet in control of its clients, including your PWA. It needs to be activated first. When the service worker is ready to control its clients, the activate event will fire. This doesn't mean, though, that the page that registered the service worker will be managed. By default, the service worker will not take control until the next time you navigate to that page, either due to reloading the page or re-opening the PWA. You can listen for events in the service worker's global scope using the self object. serviceworker.js Copy code // This code executes in its own worker or thread self.addEventListener("install", event => { console.log("Service worker installed"); }); self.addEventListener("activate", event => { console.log("Service worker activated"); }); UPDATING A SERVICE WORKER # Service workers get updated when the browser detects that the service worker currently controlling the client and the new (from your server) version of the same file are byte-different. Warning When updating your service worker, do so without renaming it. Do not even add file hashes to the filename. Otherwise, the browser will never get the new version of your service worker! After a successful installation, the new service worker will wait to activate until the existing (old) service worker no longer controls any clients. This state is called "waiting", and it's how the browser ensures that only one version of your service worker is running at a time. Refreshing a page or reopening the PWA won't make the new service worker take control. The user needs to close or navigate away from all tabs and windows using the current service worker and then navigate back. Only then will the new service worker to take control. Visit this service worker lifecycle article for more information. SERVICE WORKER LIFESPAN # Once installed and registered, a service worker can manage all network requests within its scope. It runs on its own thread, with activation and termination controlled by the browser. This lets it work even before or after your PWA is open. While service workers run on their own thread, there is no guarantee that in-memory state will persist between runs of a service worker, so make sure anything you want to reuse on each run is available either in IndexedDB or some other persistent storage. If not already running, a service worker will start whenever a network request in its scope is asked for, or when a triggering event, like periodic background sync or a push message, is received. Service workers don't live indefinitely. While exact timings differ between browsers, service workers will be terminated if they've been idle for a few seconds, or if they've been busy for too long. If a service worker has been terminated and an event occurs that would start it up, it will restart. CAPABILITIES # With a registered and active service worker, you have a thread with a completely different execution lifecycle than the main one on your PWA. However, by default, the service worker file itself has no behavior. It won't cache or serve any resources, as this has to be done by your code. You'll find out how in the following chapters. Service worker's capabilities are not just for proxy or serving HTTP requests; other features are available on top of it for other purposes, such as background code execution, web push notifications, and process payments. We'll discuss these additions in the capabilities chapter. RESOURCES # * Service Worker API (MDN) * Service Worker mindset * WebKit Workers at your service * ES Modules in Service Workers * Service worker lifecycle NEXT AND PREVIOUS LESSONS Prev005 ASSETS AND DATA Next007 CACHING You can use the Cache Storage API to download, store, delete or update assets on the device. Then these assets can be served on the device without needing a network request. We want to help you build beautiful, accessible, fast, and secure websites that work cross-browser, and for all of your users. This site is our home for content to help you on that journey, written by members of the Chrome team, and external experts. CONTRIBUTE * File a bug * View source RELATED CONTENT * developer.chrome.com * Chrome updates * Case studies * Podcasts * Shows CONNECT * Twitter * YouTube * * Chrome * Firebase * Google Cloud Platform * All products Dark theme Choose language ENGLISH (en) * Terms & Privacy * Community Guidelines Except as otherwise noted, the content of this page is licensed under the Creative Commons Attribution 4.0 License, and code samples are licensed under the Apache 2.0 License. For details, see the Google Developers Site Policies. By Chrome DevRel