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

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

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 缓存的优先级最低,只有在网络不可用或者其他缓存都未命中时才会生效。

相关推荐
董世昌4112 小时前
js怎样控制浏览器前进、后退、页面跳转?
开发语言·前端·javascript
走,带你去玩12 小时前
uniapp live-pusher + 腾讯云直播
前端·javascript·uni-app
徐同保12 小时前
electron打包项目
前端·javascript·electron
Maybyy12 小时前
如何在项目里面添加一个可以左右翻动并显示指定日期的日历
前端·vue.js
柯南二号12 小时前
【大前端】【Android】用 Python 脚本模拟点击 Android APP —— 全面技术指南
android·前端·python
Arvin_Rong12 小时前
前端动态 API 生成与封装:前端 API 调用的一种思路
前端
2401_8603195212 小时前
DevUI组件库实战:从入门到企业级应用的深度探索,如何实现支持表格扩展和表格编辑功能
前端·前端框架
LYFlied12 小时前
从循环依赖检查插件Circular Dependency Plugin源码详解Webpack生命周期以及插件开发
前端·webpack·node.js·编译原理·plugin插件开发
麒qiqi12 小时前
【Linux 系统编程】文件 IO 与 Makefile 核心实战:从系统调用到工程编译
java·前端·spring
IT_陈寒12 小时前
Vue3 性能优化实战:从10秒到1秒的5个关键技巧,让你的应用飞起来!
前端·人工智能·后端