如何用 cache 参数控制 Fetch 是否读取浏览器自带的缓存

Fetch 的 cache 参数决定浏览器如何复用缓存响应,而非禁用缓存;其值包括 default(遵HTTP头)、no-store(不读不写)、reload(强制网络请求)、no-cache(先校验)、force-cache(优先用过期缓存)、only-if-cached(仅缓存,无则报错)。Fetch 的 cache 参数直接决定请求是否复用浏览器已缓存的响应,而不是简单地"禁用缓存"。它不绕过 HTTP 缓存规则,而是告诉浏览器在满足缓存条件的前提下,如何决策:是读缓存、忽略缓存、还是强制校验。cache 参数的可选值及行为该参数取值为字符串,常见选项有:'default':默认行为。遵循 HTTP 缓存头(如 Cache-Control、Expires)。若响应可缓存且未过期,直接返回缓存;否则发起网络请求。 'no-store':完全跳过缓存读写。每次请求都走网络,响应也不存入缓存。适合敏感数据或调试场景。 'reload':强制发起新请求,忽略所有本地缓存(包括 memory cache 和 disk cache),但响应仍可能被缓存(取决于响应头)。 'no-cache':允许读缓存,但必须先向服务器验证(发送带 If-None-Match 或 If-Modified-Since 的条件请求)。服务器返回 304 时复用缓存,200 则更新缓存并返回新内容。 'force-cache':尽可能使用缓存,即使已过期也先返回缓存内容(stale-while-revalidate 类似效果),再异步校验更新。注意:不是所有浏览器都完全支持此行为,尤其在过期严重时可能仍发请求。 'only-if-cached':只从缓存中取,不发起网络请求。若无可用缓存则报错(TypeError: Failed to fetch)。常配合 credentials: 'omit' 使用,避免跨域问题。与 HTTP 缓存头的协同关系cache 参数不会覆盖服务器返回的缓存控制头,而是与之配合工作: Zeemo AI 一款专业的视频字幕制作和视频处理工具

相关推荐
HalvmånEver1 小时前
MySQL事务(二)
数据库·mysql
m0_470857641 小时前
CSS如何实现表单元素的统一样式_使用CSS变量控制输入框状态
jvm·数据库·python
MATLAB代码顾问1 小时前
粒子群优化算法(PSO)原理与Python高级实现
开发语言·python·算法
会编程的土豆1 小时前
mysql数据类型
数据库·mysql
wang3zc2 小时前
如何正确管理浮层提示(Tooltip)显示时的页面焦点顺序
jvm·数据库·python
2401_824222692 小时前
如何导出Laravel特定时间段的订单数据 基于created_at过滤导出
jvm·数据库·python
百年孤独_2 小时前
单周期 MIPS 数据通路上层视角
python
2501_901200532 小时前
进阶设计指南之如何打印分页与自适应ER图_支持高级扩展类型
jvm·数据库·python
m0_609160492 小时前
C#怎么实现HttpClient最佳实践 C#如何用IHttpClientFactory管理HttpClient避免端口耗尽【网络】
jvm·数据库·python