前端缓存机制
前端缓存主要分为两种类型:强缓存 和协商缓存。
强缓存(HTTP Cache-Control)
- 通过设置HTTP响应头中的
Cache-Control
实现。 - 浏览器根据
Cache-Control
的值决定是否重新请求资源。 - 指令示例:
no-cache
:重新验证缓存资源。no-store
:禁止缓存。public
:允许中间缓存存储响应。private
:仅用户可缓存。max-age=<seconds>
:设置缓存时间。
协商缓存(Conditional Cache)
- 缓存过期后,浏览器通过发送请求头查询资源是否更新。
- 使用
ETag
或Last-Modified
与服务器进行验证。 - 如果资源未更新,服务器返回
304 Not Modified
。
协商缓存的HTTP头
ETag
:资源版本标识符,用于If-None-Match
。Last-Modified
:上次修改日期,用于If-Modified-Since
。
区别和使用场景
- 强缓存:适用于不常变动的资源,减少请求。
- 协商缓存:适用于可能更新的资源,验证资源更新。
实践建议
- 合理设置
Cache-Control
实现强缓存。 - 对动态内容使用
ETag
或Last-Modified
实现协商缓存。 - 结合使用两种缓存策略,优化网站性能和用户体验。