【HTML】link标签prefetch&preload

preload

<link>标签的rel属性的值为preload时,可用于在正常浏览器渲染流程早期提前加载当前页面所需资源,以提升页面性能。

除了rel属性之外还要指定:

  • href 属性中的资源路径。
  • as 属性中的资源类型。

其他优点

preload除了提前加载资源以外,使用 as 来指定要预加载的内容类型允许浏览器:

  • 更准确地优先加载资源。
  • 将资源存储在缓存中以备将来使用,在适当的情况下复用资源。
  • 对资源应用正确的内容安全策略
  • 为其设置正确的 Accept 请求标头。

as支持的值

  • audio:音频文件,通常在 <audio>中使用。
  • document:用于嵌入在 <frame><iframe> 中的 HTML 文档。
  • embed:用于嵌入在 <embed>元素中的资源。
  • fetch:通过 fetchXHR 请求访问的资源,例如 ArrayBuffer、WebAssembly 二进制文件或 JSON 文件。
  • font:字体文件。
  • image:图像文件。
  • object:要嵌入在 <object> 元素中的资源。
  • script:JavaScript 文件。
  • style:CSS 样式表。
  • track:WebVTT 文件。
  • worker:JavaScript web worker 或 shared worker。
  • video:视频文件,通常在 <video> 中使用。

cors跨域

as值为fetch或者font时有可能会涉及cors跨域需要给link标签设置crossorigin属性

使用

html 复制代码
<link rel="preload" href="style.css" as="style">
<link rel="preload" href="big-image.jpg" as="image">

prefetch

<link>标签的rel属性的值为prefetch时,用于提前加载用户下一个页面的资源。提高下一个页面加载性能。

使用

html 复制代码
<link rel="prefetch" href="/next-page.html">

区别

  • 目的preload 目标是当前页面的辅助资源,而 prefetch 是为了将来可能访问的页面做准备。
  • 资源类型preload 可以用于各种资源类型,而 prefetch 主要用于预加载链接页面的资源。
  • 优先级preload 的资源通常会被赋予更高的加载优先级,以确保它们及时可用。
相关推荐
于慨16 小时前
Lambda 表达式、方法引用(Method Reference)语法
java·前端·servlet
石小石Orz16 小时前
油猴脚本实现生产环境加载本地qiankun子应用
前端·架构
从前慢丶16 小时前
前端交互规范(Web 端)
前端
CHU72903517 小时前
便捷约玩,沉浸推理:线上剧本杀APP功能版块设计详解
前端·小程序
GISer_Jing17 小时前
Page-agent MCP结构
前端·人工智能
王霸天17 小时前
💥别再抄网上的Scale缩放代码了!50行源码教你写一个永不翻车的大屏适配
前端·vue.js·数据可视化
小领航17 小时前
用 Three.js + Vue 3 打造炫酷的 3D 行政地图可视化组件
前端·github
@大迁世界17 小时前
2026年React大洗牌:React Hooks 将迎来重大升级
前端·javascript·react.js·前端框架·ecmascript
PieroPc17 小时前
一个功能强大的 Web 端标签设计和打印工具,支持服务器端直接打印到局域网打印机。Fastapi + html
前端·html·fastapi
悟空瞎说17 小时前
深入 Vue3 响应式:为什么有的要加.value,有的不用?从设计到源码彻底讲透
前端·vue.js