Preload
preload api 接口:
<link rel="preload" as="fetch" href="http://example.com/api/v2/list" crossorigin="anonymous" />
要求:
- `as` 值为 `fetch`
- 跨域请求需要带上 crossorigin
如果要命中 preload 的数据,必须符合:
- 接口请求方法一致,URL 一致,请求头一致
需要注意的是,手动设置了请求头会导致无法从 preload 获取响应:
这就要求使用 preload 的接口必须不能添加额外的请求头,否则不会从 preload 取内容。
另外,对于跨域的接口 preload ,在使用 fetch 请求时有时需要加上
{ credentials: 'same-origin' }
的参数。另外 preload 后的响应内容只会被消费一次,消费完之后重新请求该资源会重新发出一个新的请求。
另外 在 UC 国际浏览器上, preload 不支持
as="fetch"
😓Prefetch
如果资源的 cache-control 设置了 no-store 那么 prefetch 就会失效。
Preconnect
Chrome 只能同时发起 6 条 DNS 查询(使用了新版的 async DNS resolver 的话数值不是6,但是仍然会对数量做一定的限制),因此 HTML 里面进行 preconnect 或者 dns-preconnect 的数量最好不要超过 6 条。
data:image/s3,"s3://crabby-images/0c35d/0c35d97c034fc4d6ebc3f7c69ca772997c98d06e" alt="/image/b7abb123-0b1b-4a6b-a892-c89d7af175e7/957b4146-3f11-4461-9d15-b362c4f7cfd8_Untitled.png"
对于非 http2 的资源,使用 preconnect ,并不能给该域名下的所有资源都进行 preconnect 。上图圈出来部分则是 http 1.1 的连接。
data:image/s3,"s3://crabby-images/9cde9/9cde92b684da63c4f4157a88ecac2394aea7089c" alt="/image/b7abb123-0b1b-4a6b-a892-c89d7af175e7/a92abfb6-c92a-426e-ba15-2a27200f97c2_Untitled.png"