Cache
说明:
 缓存的内容仅在当前数据节点有效,不会自动复制到其他数据节点。
构造函数
使用 
caches.default 可以获取默认的 cache 实例。// 获取默认 cache 实例const cache = caches.default;// 效果等同于 caches.defaultawait caches.open('default');
使用 
caches.open 创建指定命名空间的 cache 实例。// 创建指定命名空间的 cache 实例const cache = await caches.open(namespace);
参数
caches.open(namespace) 方法参数说明如下。| 参数名称 | 类型 | 必填 | 说明 | 
| namespace | string | 是 | 缓存命名空间。         如果该值为 "default" 则表示默认实例,也可直接使用 caches.default 获取默认实例。 | 
实例方法
match
cache.match(request: string | Request, options?: MatchOptions): Promise<Response | undefined>
注意:
cache.match 内部不会主动回源,缓存过期则会抛出 504 错误。
参数
| 参数名称 | 类型 | 必填 | 说明 | 
| request | string | Request | 是 | 请求对象,headers 说明如下。 GET request 只支持 GET 方法,当类型为 string 时,将被作为 URL 构造 Request 对象。 Range request 包含 Range 头部时,如果缓存的 Response 能够支持 Range 范围处理,返回 206 响应。 If-Modified-Since request 包含 If-Modified-Since 头部时,如果缓存的 Response 存在 Last-Modified 头部,且 Last-Modified 与 If-Modified-Since 相等,返回 304 响应。 If-None-Match | 
| options | 否 | 选项。 | 
MatchOptions
| 属性名 | 类型 | 示例值 | 说明 | 
| ignoreMethod | boolean | true | 是否忽略 Request 的 method。为 true 时,会忽略 Request 原来的 method,作为 GET 处理。 | 
put
cache.put(request: string | Request, response: Response): Promise<undefined>
尝试使用给定的 request 作为缓存 key,将 response 添加到缓存。无论缓存是否成功,均返回 
Promise<undefined> 对象。注意:
 当参数 response 对象的 Cache-Control 头部表示不缓存时,抛出 413 错误。
参数
| 参数名称 | 类型 | 必填 | 说明 | 
| request | string | Request | 是 | 缓存 key,说明如下。                 GET 参数 request 仅支持 GET 方法,其他方法,将抛出参数错误。           string | 
| response | 是 | 缓存内容,说明如下。 Cache-Control 支持 s-maxage、max-age、no-store、no-cache、private;其中 no-store、no-cache、private 均表示不缓存,cache.put 将返回 413 错误。           Pragma ETag Last-Modified 416 Range Not Satisfiable | 
参数限制
cache.put 使用以下的参数值,将抛出参数错误:参数 
request 为 GET 方法之外的其他方法.参数 
response 状态码为 206 Partial Content。 参数 
response 包含 Vary: *头部。delete
cache.delete(request: string | Request, options?: DeleteOptions): Promise<boolean>
删除 request 关联的缓存 response。未发生网络错误时, 总返回 Promise,并包含 true,反之包含 false。
参数
| 参数名称 | 类型 | 必填 | 说明 | 
| request | string | Request | 是 | 缓存 key,说明如下。         GET 参数 request 仅支持 GET 方法           string | 
| options | 否 | 配置选项。 | 
DeleteOptions
| 属性名 | 类型 | 示例值 | 说明 | 
| ignoreMethod | boolean | true | 是否忽略 request 的方法名。为 true 时,会忽略 Request 原来的方法,作为 GET 处理 |