0

0

JavaScriptServiceWorker怎样实现离线应用【教程】

狼影

狼影

发布时间:2026-01-22 12:40:48

|

892人浏览过

|

来源于php中文网

原创

Service Worker 注册失败主因是路径或作用域错误:路径须为根目录相对路径(如"/sw.js"),scope需显式设为"/"才能覆盖全站;必须HTTPS(localhost除外),且页面加载完成后注册。

javascriptserviceworker怎样实现离线应用【教程】

Service Worker 注册失败的常见原因

注册不成功,八成是路径或作用域问题。navigator.serviceWorker.register() 的第一个参数必须是相对于站点根目录的路径(比如 "/sw.js"),不能写成 "./sw.js""sw.js"。另外,Service Worker 只能控制其脚本所在路径及子路径下的页面——如果 sw.js 放在 /assets/sw.js,它默认只能接管 /assets/ 下的页面,得用 scope 选项显式设为 "/" 才能覆盖整个站点。

还要确认当前环境:必须是 HTTPS(本地 localhost 除外),且页面已完全加载后再调用注册(避免在 document.write 或未就绪的 DOM 中执行)。

  • 检查浏览器控制台是否有 Failed to register a ServiceWorker 错误,点开看具体提示
  • 打开 Application → Service Workers 面板,确认状态是否为 “activated” 而非 “waiting” 或 “red”
  • 首次注册后刷新页面不会立即生效,需关掉所有标签页再重开,或勾选 “Update on reload” 强制更新

缓存静态资源时如何区分 runtime 和 install 时机

install 事件适合预缓存确定不变的资源(如 HTML、CSS、JS、图标),用 caches.open().addAll() 一次性写入;fetch 事件则处理运行时请求(比如 API 响应、用户上传的图片),需要手动 event.respondWith() 并决定是否缓存、缓存多久。

混用这两类逻辑容易导致离线时拿不到动态内容,或者缓存爆炸。例如把用户头像 URL 直接塞进 install 列表,下次头像更新就永远看不到新图。

立即学习Java免费学习笔记(深入)”;

Android应用程序消息处理机制分析 中文WORD版
Android应用程序消息处理机制分析 中文WORD版

Android应用程序是通过消息来驱动的,系统为每一个应用程序维护一个消息队例,应用程序的主线程不断地从这个消息队例中获取消息(Looper),然后对这些消息进行处理(Handler),这样就实现了通过消息来驱动应用程序的执行,本文将详细分析Android应用程序的消息处理机制。有需要的朋友可以下载看看

下载
  • 预缓存清单建议用构建工具生成(如 Workbox 的 generateSW),避免手写漏项
  • API 请求别盲目缓存,加判断:只缓存 GET 请求,忽略带 Authorizationcookie 的敏感请求
  • caches.match(event.request) 查缓存前,先用 new URL(event.request.url).origin === location.origin 过滤跨域请求,防止意外拦截 CDN 或第三方资源

fetch 事件中 return 与 event.respondWith() 的区别

fetch 事件监听器里,不能直接 return fetch(...),必须用 event.respondWith() 包裹响应 Promise。否则浏览器会忽略你的逻辑,走默认网络请求——这会导致离线时白屏,因为没拦截到请求。

常见错误写法:self.addEventListener('fetch', e => { if (e.request.url.endsWith('.png')) return caches.match(e.request); }) —— 这里 return 只是退出函数,不是响应请求。

  • 正确写法是:e.respondWith(caches.match(e.request).then(r => r || fetch(e.request)))
  • 注意 respondWith() 内部 Promise 必须 resolve 一个 Response 对象,不能是 nullundefined,否则报 TypeError: Failed to execute 'respondWith' on 'FetchEvent'
  • 想跳过缓存直连网络?仍需 e.respondWith(fetch(e.request)),不能省略包裹

调试离线行为时最该盯住的三个地方

离线效果不理想,往往不是代码写错,而是测试方式不对。重点看这三处:

  • Chrome DevTools 的 Application → Service Workers 面板右上角勾选 “Offline”,再刷新——别只关 WiFi,那可能还走本地 DNS 缓存或 HTTP/2 推送
  • Network 面板里每个请求的 “Size” 列显示 (from ServiceWorker) 才算真命中缓存;若显示 (from disk cache) 或空白,说明没走 SW
  • Console 里手动执行 caches.keys().then(keys => keys.forEach(k => caches.delete(k))) 清掉旧缓存,再重新 install,避免旧版本 SW 持续干扰

缓存策略看似简单,但 cache-firstnetwork-firststale-while-revalidate 的取舍,取决于资源更新频率和用户体验容忍度——这些细节不会报错,但会悄悄让离线体验变味。

相关专题

更多
css
css

css是层叠样式表,用来表现HTML或XML等文件样式的计算机语言,不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

524

2023.06.15

css居中
css居中

css居中:1、通过“margin: 0 auto; text-align: center”实现水平居中;2、通过“display:flex”实现水平居中;3、通过“display:table-cell”和“margin-left”实现居中。本专题为大家提供css居中的相关的文章、下载、课程内容,供大家免费下载体验。

265

2023.07.27

css如何插入图片
css如何插入图片

cssCSS是层叠样式表(Cascading Style Sheets)的缩写。它是一种用于描述网页或应用程序外观和样式的标记语言。CSS可以控制网页的字体、颜色、布局、大小、背景、边框等方面,使得网页的外观更加美观和易于阅读。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

759

2023.07.28

css超出显示...
css超出显示...

在CSS中,当文本内容超出容器的宽度或高度时,可以使用省略号来表示被隐藏的文本内容。本专题为大家提供css超出显示...的相关文章,相关教程,供大家免费体验。

539

2023.08.01

css字体颜色
css字体颜色

CSS中,字体颜色可以通过属性color来设置,用于控制文本的前景色,字体颜色在网页设计中起到很重要的作用,具有以下表现作用:1、提升可读性;2、强调重点信息;3、营造氛围和美感;4、用于呈现品牌标识或与品牌形象相符的风格。

761

2023.08.10

什么是css
什么是css

CSS是层叠样式表(Cascading Style Sheets)的缩写,是一种用于描述网页(或其他基于 XML 的文档)样式与布局的标记语言,CSS的作用和意义如下:1、分离样式和内容;2、页面加载速度优化;3、实现响应式设计;4、确保整个网站的风格和样式保持统一。

605

2023.08.10

css三角形怎么写
css三角形怎么写

CSS可以通过多种方式实现三角形形状,本专题为大家提供css三角形怎么写的相关教程,大家可以免费体验。

561

2023.08.21

css设置文字颜色
css设置文字颜色

CSS(层叠样式表)可以用于设置文字颜色,这样做有以下好处和优势:1、增加网页的可视化效果;2、突出显示某些重要的信息或关键字;3、增强品牌识别度;4、提高网页的可访问性;5、引起不同的情感共鸣。

397

2023.08.22

html编辑相关教程合集
html编辑相关教程合集

本专题整合了html编辑相关教程合集,阅读专题下面的文章了解更多详细内容。

38

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3万人学习

CSS教程
CSS教程

共754课时 | 22.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号