Google 工作箱更改范围?

Google Workbox Change Scope?

这是我的服务人员:

// This is the "Offline page" service worker

importScripts('https://storage.googleapis.com/workbox-cdn/releases/5.1.2/workbox-sw.js');

const CACHE = "pwabuilder-page";

// TODO: replace the following with the correct offline fallback page i.e.: const offlineFallbackPage = "offline.html";
const offlineFallbackPage = "/error/404.html";

self.addEventListener("message", (event) => {
  if (event.data && event.data.type === "SKIP_WAITING") {
    self.skipWaiting();
  }
});

self.addEventListener('install', async (event) => {
  event.waitUntil(
    caches.open(CACHE)
      .then((cache) => cache.add(offlineFallbackPage))
  );
});

if (workbox.navigationPreload.isSupported()) {
  workbox.navigationPreload.enable();
}

self.addEventListener('fetch', (event) => {
  if (event.request.mode === 'navigate') {
    event.respondWith((async () => {
      try {
        const preloadResp = await event.preloadResponse;

        if (preloadResp) {
          return preloadResp;
        }

        const networkResp = await fetch(event.request);
        return networkResp;
      } catch (error) {

        const cache = await caches.open(CACHE);
        const cachedResp = await cache.match(offlineFallbackPage);
        return cachedResp;
      }
    })());
  }
});

service worker 存储在 /src/pwa/sw.js

我如何允许 service worker 的范围 运行 在 / 而不是 /src/pwa/ ?

我使用动态 JS 加载器加载我所有的 javascript 文件,当我尝试加载 PWA 加载器时,它显示“范围 /src/pwa/ 错误”

Service Worker 的最大作用域由 Service Worker 脚本文件的位置决定。您提到您的脚本是从 /src/pwa/sw.js 提供的,因此最大范围是 /src/pwa/

如果您希望范围能够控制您网站上的所有页面,则需要在托管在 /sw.js 时注册您的服务工作者。

有更多背景资料