Service Worker 是运行在浏览器后台的可编程代理层,支持拦截请求、缓存管理、推送通知和离线访问;需 HTTPS 注册,独立线程运行,无法访问 DOM,通过 install/activate/fetch 事件实现缓存策略与离线能力。

Service Worker 是运行在浏览器后台的脚本,独立于网页主线程,能拦截网络请求、管理缓存、实现推送通知和离线访问。它本质是一个可编程的代理层,让开发者精细控制资源加载逻辑,是构建可靠离线应用的核心机制。
Service Worker 的核心能力
它不是普通 JS 脚本,有明确生命周期和限制:
- 必须通过 HTTPS(本地 localhost 除外)注册,保障安全
- 运行在独立线程,无法访问 DOM 或 window 对象
- 默认不持久:关闭所有页面后可能被终止,但可通过 skipWaiting() 和 clients.claim() 提升激活稳定性
- 支持 fetch 和 cache API,可缓存静态资源、API 响应甚至流式内容
注册与安装 Service Worker
在网页中注册只需一行 JS,通常放在 main.js 或入口脚本顶部:
if ('serviceWorker' in navigator) {
navigator.serviceWorker.register('/sw.js')
.then(reg => console.log('SW registered', reg))
.catch(err => console.error('SW registration failed', err));
}
立即学习“Java免费学习笔记(深入)”;
标签: css javascript java html js 前端 go 浏览器 app ai win red
还木有评论哦,快来抢沙发吧~