HTML怎样预获取文档的后续页面_HTML预获取文档后续页面策略【策略】

3次阅读

rel=”prefetch”仅在浏览器空闲且低优先级带宽可用时触发,适用于同源可预测后续页面的文档等可缓存资源,需指定as属性和正确路径,chrome/edge支持较好而safari更保守。

HTML怎样预获取文档的后续页面_HTML预获取文档后续页面策略【策略】

html rel="prefetch" 什么时候真正起作用

它只在浏览器空闲、低优先级带宽可用时才加载,不是“立刻取”。很多开发者以为加了就一定能提前拿到资源,结果首屏没变化,后续跳转也没变快——大概率是触发条件没满足。

  • 必须是用户可能访问的后续页面(比如分页链接、下一步表单页),且路径明确可预测
  • 目标资源需同源,跨域需配 crossorigin 属性,否则静默失败
  • Chrome 和 Edge 支持较好;Safari 对 prefetch 的调度更保守,有时压根不发请求
  • 不要对 /api/xxx 这类接口prefetch,它只适用于文档、脚本、样式等可缓存资源

<link rel="prefetch"> 的写法和常见错误

最常错的是把 URL 写成相对路径但没考虑当前页面位置,或者漏掉 as 提示类型,导致浏览器无法正确设置请求头或缓存策略。

  • 必须指定 href,且建议用绝对路径或根相对路径(如 /page2.html),避免 ./next.html 在嵌套路由下解析错
  • 强烈建议加上 as="document",否则默认按 as="fetch" 处理,可能被降权甚至忽略
  • 别在 里放,必须在 中,否则多数浏览器不识别
  • 错误示例:<link rel="prefetch" href="next.html"> → 缺 as,路径易错,无 crossorigin 跨域支持
  • 正确示例:<link rel="prefetch" href="/pages/step2.html" as="document" crossorigin>

prefetch 和 preload、prerender 的关键区别

三者常被混用,但行为完全不同:preload 是“现在就要”,prefetch 是“以后可能要”,prerender 是“干脆把整个页面渲染好藏起来”——后者已被 Chrome 废弃,别再用。

  • preload:强制高优先级加载,用于当前页马上要用的资源(如首屏字体、关键 js),会阻塞 dom 解析
  • prefetch:低优先级后台加载,不影响当前页性能,适合用户操作后才出现的资源
  • prerender:已从 Chromium 移除,Safari 也不支持,rel="prerender" 现在只是个无效字符串
  • 别用 prefetch 替代懒加载图片或组件,它不触发执行,只存到 http 缓存里

怎么验证 prefetch 是否生效

不能只看 Network 面板有没有请求,得确认它是否进了缓存、并在后续导航中被复用。很多情况下请求发了,但因为缓存策略或 MIME 类型不匹配,实际没用上。

  • chrome devtools 的 Network 标签页,筛选 Initiator 列为 Prefetch 的请求
  • 点开该请求,检查 Response Headers 中是否有 X-Content-Type-Options: nosniffContent-Type 不是 text/html(文档类需匹配)
  • 跳转到目标页面后,在 Network 面板刷新,看该 HTML 是否显示 from disk cachefrom memory cache
  • 如果看到 from service worker,说明你的 SW 拦截了,prefetch 可能被绕过

实际用的时候,最容易被忽略的是 as="document" 和跨域配置。没这两项,prefetch 很可能只是安静地失败,连控制台警告都没有。

text=ZqhQzanResources