HTTP
缓存策略 分为 => 「强制缓存」 和 「协商缓存」
为什么需要 HTTP
缓存 呢 ?
直接使用缓存速度 >> 远比重新请求快
缓存对象有那些呢 ?
「图片」 「JS文件」 「CSS文件」 等等
Response Header
中的Cache-Control
属性Cache-Control
属性值有两种 :「no-cache
」 和 「max-age= xxx
」① 属性为「
no-cache
」 时 表示不需要 强制缓存 , 每次需要重新调接口 ;
② 属性为「
max-age= xxx
」 时 表示需要 强制缓存 , 缓存时长为xxx
秒,超过时长需要重新请求 ;
「数据发生更新」 : 返回 状态码
200
, 返回最新数据,取最新数据;
「数据未发生更新」 : 返回 状态码
304
, 取缓存数据;
2
中形式第Ⅰ种形式 ,涉及参数
Last-Modified
:资源最后更新时间;If-Modified-Since
: 传递给服务端的参数 ,判断与最新资源更新时间比较 「相等」 => 返回
304
; 「不相等」 => 重新设置Last-Modified
,返回200
获取最新数据;
第Ⅱ种形式 ,涉及参数
两种形式的区别
Etag
可以精确到 毫秒 , 而 Last-Modified
只能判断秒级别的