登录
首页 >  文章 >  前端

Service Worker生命周期面试题整理

时间:2026-05-22 17:48:44 245浏览 收藏

Service Worker的生命周期并非简单的线性流程,而是一个由状态驱动、高度异步且容易被误解的复杂机制——注册只是提交申请,install和activate可能被阻塞、跳过甚至失败;不正确使用waitUntil会导致缓存不可靠,忽略skipWaiting和clients.claim会让更新“静默卡住”,而不及时清理旧缓存则可能引发磁盘爆满;真正掌握它,需要穿透控制台日志直击运行时状态(如controller.state或registration.waiting),理解每个钩子背后的权责边界与常见陷阱,才能让离线能力稳定落地而非徒有其表。

HTML面试题Service Worker_html面试题Service Worker生命周期【整理】

Service Worker 生命周期不是线性流程,而是状态驱动的异步过程;注册成功不等于立即生效,install 和 activate 都可能被阻塞或跳过。

为什么 navigator.serviceWorker.register() 后页面没离线?

注册只是“提交申请”,不触发安装。浏览器会按需(比如页面刷新、导航到同 scope 下新页面)才启动 install 流程。常见误判点:

  • 注册脚本放在 末尾但未加 window.addEventListener('load', ...),导致注册时机过早或失败
  • 脚本路径错误,返回 404 —— 此时控制台不会报明显错误,但 chrome://serviceworker-internals 里能看到 “failed to fetch”
  • 作用域(scope)配置越界,例如用 register('/sw.js', {scope: '/admin/'}) 却在 / 下访问,SW 不会控制该页面
  • 开发中反复注册未更新版本号,浏览器判定为“冗余”,直接跳过 install

install 事件里必须用 event.waitUntil()

不调用 waitUntil(),install 会瞬间完成,后续缓存操作变成“后台任务”,无法保证资源写入成功。更糟的是:如果缓存失败但没被拦截,SW 会进入 installed 状态却无有效缓存。

  • waitUntil() 接收一个 Promise,只要它 reject,整个 install 就失败,SW 进入 redundant 状态
  • 常见错误是忘记 return:写成 event.waitUntil(caches.open(...)) 而不是 event.waitUntil(caches.open(...).then(...))
  • 缓存列表含 404 资源时,caches.addAll() 会整体失败 —— 建议拆成单个 cache.add() 并捕获错误,或预检资源可用性

activate 事件里不清理旧缓存,会导致磁盘爆满

每次更新 SW 脚本,旧版本仍驻留,其缓存也继续存在。若不主动清理,caches.keys() 列表会持续膨胀,尤其在开发阶段频繁改名缓存(如 v1v2)。

  • 激活阶段用 event.waitUntil() 包裹清理逻辑,确保新 SW 完全接管前旧缓存已删
  • 典型写法:caches.keys().then(keys => Promise.all(keys.map(k => k.startsWith('my-cache-') && caches.delete(k))))
  • 注意:不能在 install 阶段删旧缓存 —— 此时旧 SW 可能还在运行,caches.delete() 会失败

怎么确认当前 SW 处于哪个状态?

别只看 console 日志,实际状态得查运行时对象:

  • 页面中检查 navigator.serviceWorker.controller?.state(当前控制页面的 SW 状态)
  • 通过 registration.installing / registration.waiting / registration.active 获取对应实例,再读其 .state
  • 状态值只能是字符串:"installing""installed""activating""activated""redundant"
  • 最易忽略的是 "waiting":install 成功但没激活,通常因为有旧 SW 正在控制页面 —— 此时需手动调用 skipWaiting() 或等用户关闭所有标签页

生命周期里没有“运行中”概念,只有事件触发点;self.skipWaiting()clients.claim() 是让更新立即生效的关键动作,但它们本身不改变状态机,只影响控制权交接时机。

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《Service Worker生命周期面试题整理》文章吧,也可关注golang学习网公众号了解相关技术文章。

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>