前端缓存机制
前端缓存主要分为两种类型:强缓存 和协商缓存。
强缓存(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实现协商缓存。 - 结合使用两种缓存策略,优化网站性能和用户体验。