0

0

CSS样式的离线存储方案_利用Service Worker缓存CSS

P粉602998670

P粉602998670

发布时间:2026-02-27 12:59:31

|

675人浏览过

|

来源于php中文网

原创

service worker 缓存 css 的关键是 install 阶段预缓存且路径与 html 中 link href 完全一致;fetch 事件需判断 event.request.destination === 'style';更新需处理 sw 生命周期;@import 和 url() 不被拦截,须单独缓存;推荐用内容哈希文件名确保路径三者对齐。

css样式的离线存储方案_利用service worker缓存css

Service Worker 缓存 CSS 文件的最小可行写法

直接能用、不报错的关键是:在 install 阶段预缓存,且路径必须和 HTML 中 <link rel="stylesheet">href 完全一致(包括斜杠、查询参数、大小写)。

常见错误是把 styles.css 写成 /styles.css 或漏掉 ?v=1.2,导致浏览器请求时找不到匹配缓存,回退到网络——看起来“没生效”。

  • 缓存策略建议用 CacheFirst(优先读缓存),CSS 一般不常变,且首次加载后几乎不会重请求
  • 务必在 fetch 事件中加判断:event.request.destination === 'style',避免误缓存图片或脚本
  • 示例片段:
self.addEventListener('fetch', event => {
  if (event.request.destination === 'style') {
    event.respondWith(
      caches.match(event.request).then(res => res || fetch(event.request))
    );
  }
});

CSS 缓存更新不生效?检查 SW 注册与激活时机

Service Worker 不会自动更新已激活的缓存。用户刷新页面时,新 SW 只注册、等待旧 SW 控制页数归零才激活;而旧缓存仍被复用,导致改了 CSS 却看不到效果。

根本原因不是缓存逻辑写错了,而是生命周期没理清。

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

Spell.tools
Spell.tools

高颜值AI内容营销创作工具

下载
  • 开发阶段可调用 navigator.serviceWorker.getRegistration().then(r => r?.update()) 强制检查更新
  • 上线后推荐在 waiting 状态时提示用户刷新,或调用 skipWaiting()(需确保 CSS 更新是向后兼容的)
  • 调试时打开 Chrome DevTools → Application → Service Workers,勾选 “Update on reload”,再硬刷(Ctrl+Shift+R)

imported CSS(@import)会被 SW 自动缓存吗?

不会。Service Worker 只拦截主文档发起的网络请求,@import 是 CSS 解析器内部行为,触发的请求不会经过 SW 的 fetch 事件。

这意味着:只缓存了 main.css,但它里面写了 @import "theme.css",后者仍走网络,失去离线能力。

  • 解决办法只有两个:把 @import 拆成 HTML 中多个 <link>,或用构建工具内联(如 PostCSS 插件)
  • 注意:CSS 中的 url()(比如字体、背景图)同理不被 SW 拦截,需单独列入缓存列表
  • 验证方式:Network 面板里看 Size 列是否显示 from cache,而非 from ServiceWorker

缓存 CSS 时要不要加版本前缀或哈希?

要,但不是为了“让缓存失效”,而是为了“让缓存更稳”。SW 缓存靠 URL 做 key,如果总用 styles.css,每次部署都得手动清旧缓存或跳过等待,容易出错。

更可靠的做法是让文件名本身带内容哈希,比如 styles.a1b2c3.css,这样新旧版本天然隔离,无需额外清理逻辑。

  • 构建工具(Vite/Webpack)默认支持 filenameHashing: true,输出带哈希的 CSS 文件
  • SW 脚本里缓存列表也得同步用这个带哈希的路径,不能写死 styles.css
  • 别用时间戳或版本号(如 styles.css?v=2.1)——CDN 或中间代理可能忽略查询参数,导致缓存穿透

真正麻烦的从来不是怎么存 CSS,而是怎么确保 HTML 加载时用的路径、SW 缓存的路径、构建输出的路径三者始终对齐。稍有脱节,就变成“以为缓存了,其实没生效”。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

995

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

808

2023.11.06

chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

995

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

808

2023.11.06

html5播放器怎么用
html5播放器怎么用

本合集全面介绍HTML5播放器的使用方法,涵盖基础语法、自定义控制、兼容性处理及实战示例。阅读专题下面的文章了解更多详细内容。

0

2026.02.27

Golang 实际项目案例:从需求到上线
Golang 实际项目案例:从需求到上线

《Golang 实际项目案例:从需求到上线》以真实业务场景为主线,完整覆盖需求分析、架构设计、模块拆分、编码实现、性能优化与部署上线全过程,强调工程规范与实践决策,帮助开发者打通从技术实现到系统交付的关键路径,提升独立完成 Go 项目的综合能力。

18

2026.02.26

Golang Web 开发路线:构建高效后端服务
Golang Web 开发路线:构建高效后端服务

《Golang Web 开发路线:构建高效后端服务》围绕 Go 在后端领域的工程实践,系统讲解 Web 框架选型、路由设计、中间件机制、数据库访问与接口规范,结合高并发与可维护性思维,逐步构建稳定、高性能、易扩展的后端服务体系,帮助开发者形成完整的 Go Web 架构能力。

17

2026.02.26

Golang 并发编程专题:掌握多核时代的核心技能
Golang 并发编程专题:掌握多核时代的核心技能

《Golang 并发编程专题:掌握多核时代的核心技能》系统讲解 Go 在并发领域的设计哲学与实践方法,深入剖析 goroutine、channel、调度模型与并发安全机制,结合真实场景与性能思维,帮助开发者构建高吞吐、低延迟、可扩展的并发程序,全面提升多核时代的工程能力。

16

2026.02.26

batoto漫画官网入口与网页版访问指南
batoto漫画官网入口与网页版访问指南

本专题系统整理batoto漫画官方网站最新可用入口,涵盖最新官网地址、网页版登录页面及防走失访问方式说明,帮助用户快速找到batoto漫画官方平台,稳定在线阅读各类漫画内容。

431

2026.02.25

热门下载

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

精品课程

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

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.5万人学习

CSS教程
CSS教程

共754课时 | 36.7万人学习

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

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