【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 的资源通常会被赋予更高的加载优先级,以确保它们及时可用。
相关推荐
Soulkey37 分钟前
复刻小红书Web端打开详情过渡动画
前端
yuki_uix39 分钟前
你点了「保存」之后,数据都经历了什么?
前端
猪头男1 小时前
【从零开始学习Vue|第六篇】生命周期
前端
zheshiyangyang2 小时前
前端面试基础知识整理【Day-7】
前端·面试·职场和发展
猫头虎3 小时前
web开发常见问题解决方案大全:502/503 Bad Gateway/Connection reset/504 timed out/400 Bad Request/401 Unauthorized
运维·前端·nginx·http·https·gateway·openresty
qq_24218863323 小时前
3389端口内网转发概述
前端·经验分享·html
Never_Satisfied3 小时前
在JavaScript / HTML中,数组查找第一个符合要求元素
开发语言·javascript·html
伊泽瑞尔3 小时前
2025年终总结
前端·程序员·ai编程
uhakadotcom4 小时前
Hono v4.12.0 发布!路由提速2倍+,JSON响应飞起来
前端·面试·github
少云清4 小时前
【UI自动化测试】10_web自动化测试 _frame切换、多窗口切换
前端·web自动化测试