浏览器有哪几种缓存,各种缓存的优先级是什么样的?

一、在浏览器中,常见的有四种缓存

1、强制缓存

通过设置 Cache-Control 和 Expires 等响应头实现,可以让浏览器直接从本地缓存中读取资源而不发起请求。

2、协商缓存

通过设置 Last-Modified 和 ETag 等响应头实现,可以让浏览器发送条件请求,询问服务器是否有更新的资源。如果服务器返回 304 Not Modified 响应,则表示客户端本地缓存仍然有效,可直接使用缓存的资源。

3、Service Worker 缓存

Service Worker 是一种特殊的 JS 脚本,可以拦截网络请求并返回缓存的响应,以实现离线访问和更快的加载速度等功能。

4、Web Storage 缓存

包括 localStorage 和 sessionStorage。localStorage 用于存储用户在网站上的永久性数据,而 sessionStorage 则用于存储用户会话过程中的临时数据。

二、常见缓存的优先级如下:(从高到低)

① Service Worker 缓存

由于其可以完全控制网络请求,因此具有最高的优先级,即使是强制缓存也可以被它所覆盖。

② 强制缓存

如果存在强制缓存,并且缓存没有过期,则直接使用缓存,不需要向服务器发送请求。

③ 协商缓存

如果强制缓存未命中,但协商缓存可用,则会向服务器发送条件请求,询问资源是否更新。如果服务器返回 304 Not Modified 响应,则直接使用缓存。

④ Web Storage 缓存

Web Storage 缓存的优先级最低,只有在网络不可用或者其他缓存都未命中时才会生效。

相关推荐
JarvanMo3 分钟前
用 Flutter、SwiftUI 和 Compose 写同一个界面:一份真实开发者的实测报告
前端
可以吧可以吧4 分钟前
前端vue jenkins打包资源增加阿里云oss+cdn加速
前端·vue.js·jenkins
hashiqimiya10 分钟前
vue项目的选择星级样式和axios依赖调用
前端·javascript·vue.js
我爱娃哈哈12 分钟前
SpringBoot + RabbitMQ + Redis + MySQL:社交平台私信发送、已读状态同步与历史消息缓存实战
spring boot·缓存·java-rabbitmq
沛沛老爹13 分钟前
Web开发者实战AI Agent:基于Dify的多模态文生图与文生视频智能体项目
前端·人工智能·llm·agent·rag·web转型
哟哟耶耶13 分钟前
Plugin-前端相关插件了解
前端
不一样的少年_15 分钟前
老王请假、客户开喷、我救火:一场递归树的性能突围战
前端·javascript·性能优化
梵得儿SHI20 分钟前
Vue Router 进阶实战:嵌套路由 / 导航守卫 / 懒加载全解析(含性能优化 + 避坑指南)
前端·javascript·vue.js·嵌套路由与命名视图·实现复杂页面结构·子路由配置要点·全局/路由/组件三种守卫用法
xjt_090125 分钟前
Chrome 截取 整个网页(全页截图 非滚动手动截图)
前端·chrome
K哥112526 分钟前
【Redis】缓存策略
数据库·redis·缓存