如何在Safari浏览器中使用Web检查器调试具有Service Worker的网页?

启用Safari Web检查器并进入Application面板
第一步,先把入口打开。点击Safari → 设置 → 高级,勾选【在菜单栏中显示‘开发’菜单】。这一步不可跳过,否则后续所有调试入口均不可见。
接着打开目标网页(确保是HTTPS或localhost协议),点击顶部菜单栏中的“开发”→“显示网页检查器”,再切换到Application标签页。如果标签页没出现,大概率是因为开发菜单没启用,或者当前页面不支持Service Worker上下文(比如file://协议页)。
查看并强制激活等待中的Service Worker
在Application面板左侧边栏展开Service Workers,右侧会列出所有已注册实例及其状态:Activated(正在控制页面)、Waiting(新版本就绪但未接管)、Installing(安装中)。
如果目标Service Worker显示为Waiting,说明新sw.js已加载但浏览器未自动激活——Safari默认不会跳过waiting阶段,必须手动干预。右键该条目,选择【Skip Waiting】。这会立即终止旧Worker、激活新Worker,并使其开始拦截fetch请求。
【此操作不可逆,旧版本缓存策略将立即失效】
检查预缓存资源是否写入Cache Storage
展开左侧Cache Storage,查看是否存在以你PWA域名命名的缓存(如https://my-pwa.dev),或自定义的CACHE_NAME(如my-pwa-cache-v1)。
如果列表为空,说明install事件未成功执行:可能原因包括sw.js路径错误(必须是根相对路径如/sw.js)、caches.open()被拒绝(如页面未通过HTTPS加载)、或event.waitUntil()内Promise被reject导致安装中断。点击某缓存名称,右侧会显示所有已缓存URL。逐个核对index.html、manifest.json、关键JS/CSS是否在列。缺失任一HTML入口文件,离线访问必然失败。
深度清理废弃Service Worker残留
方法一:在Application面板中直接卸载
对Service Workers列表中每个条目右键→选择“停止”(若为Activated)或“取消等待”(若为Waiting)→再选择“卸载”。
方法二:清除对应Cache Storage
展开Cache Storage,逐个右键各缓存名称→选择Delete;若存在以域名命名的缓存(如“https://app.example.com”),务必全部删除。
方法三:全量清除网站数据(适用于已卸载PWA但仍触发通知的场景)
点击Safari → 设置 → 网站 → 搜索目标域名 → 点击右侧“移除全部网站数据”。