资源提示符preload prefetch async defer

前言

在JavaScript中,资源提示符(Resource Hint)是一种使用<link><script>HTML标签来提示浏览器有关资源的方式。

我们正常开发中,对于这些接触不多,接下来了解一下。

1. 常用的资源提示符

以下是一些常见的资源提示符:

  • 指定资源的异步加载(Async):
xml 复制代码
<script src="script.js" async></script>
  • 指定资源的异步(Defer):
xml 复制代码
<script src="script.js" defer></script>
  • 预加载关键资源(Preload):
ini 复制代码
<link rel="preload" as="script" href="script.js">
  • 预解析关键资源(Prefetch):
ini 复制代码
<link rel="prefetch" as="script" href="script.js">
  • 预检查关键资源(Preconnect):
ini 复制代码
<link rel="preconnect" href="https://example.com">
  • 预检查关键资源(DNS-prefetch):
ini 复制代码
<link rel="dns-prefetch" href="https://example.com">

2. 案例说明

2.1 正常加载js

js的执行是自上而下,如果中间遇见资源加载,会中止dom解析,如下图所示:

案例:写一个index.html,写6千多个p标签,在标签前后分别打印p元素的个数。

index.html

html 复制代码
<script src="./index.js"></script>
<p></p>*6314个
<script src="./index.js"></script>

index.js

js 复制代码
console.log('打印***nodes', document.querySelectorAll('p'))

结果如图所示:

可以看到第一个打印为0,是因为dom没有开始解析,后面打印出全部是dom已经解析完成。

那么如何才能将script标签放在任意位置,加载js资源时,也不影响dom解析呢?接下来看看async

2.2 使用async加载js

当在script标签中使用async,不会阻塞dom解析,当资源加载完成,会立刻执行。如下图所示:

案例:加上async,将script标签放在之前,看打印结果。

index.html

html 复制代码
<script src="./index.js"></script>
<script src="./index.js" async></script>
<p></p>*3000个
<script src="./index.js"></script>

结果如下:

可以放在任何位置,资源加载完成就运行。可以看到async打印的数量是不确定的。

问题是:资源加载完成,你直接运行,没办法控制dom解析了多少。

接下来看看defer如何解决。

2.3 defer加载js

使用defer是向浏览器表明,该脚本是要在文档被解析后,但在触发 DOMContentLoaded 事件之前执行的。

包含 defer 属性的脚本将阻塞 DOMContentLoaded 事件触发,直到脚本完成加载并执行。

案例:使用defer添加在标签之前,看打印结果。

html 复制代码
<script src="./index.js" defer></script>
<script src="./index.js" async></script>
<p></p>*3000个
<script src="./index.js"></script>

结果如下:

可以看到,js,等到dom解析执行之后,才执行

2.4 module解析

script标签的设置为type="module",默认是defer进行解析。

案例:

html 复制代码
<script src="./index.js" type="module"></script>
<p></p>*3000个

结果如下:

可以看到是dom解析完成后才执行的。

2.5 preload、prefetch

prefetch

关键字 prefetch 作为元素 <link> 的属性 rel 的值,是为了提示浏览器,用户未来的浏览有可能需要加载目标资源,所以浏览器有可能通过事先获取和缓存对应资源,优化用户体验。

preload

指定页面很快就需要的资源,拿资源,不执行,只是安排脚本以更高的优先级进行下载和缓存。

使用 preloadrel 属性,将 <link> 标签转变成任何我们想要的资源的预加载器。还需要指定:

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

优先级

  • preload :直接去拿,优先级高
  • prefetch:优先级低,空闲拿

3. 总结

接下来总结一波:

  • async : 当在<script>标签中使用async属性时,该脚本将异步加载和执行,不会阻塞HTML解析器的进程。
  • defer : 与async类似,defer也允许脚本在HTML解析完成后执行,但不会阻塞解析。但与async不同,所有带有defer属性的脚本都会按照它们在HTML中出现的顺序并行加载,但在DOMContentLoaded事件触发前串行执行。
  • preload : <link rel="preload">允许开发者预加载页面未来可能需要的资源,如字体、图片或脚本。这些资源将在浏览器空闲时加载,并在需要时立即可用,从而提高了页面性能。
  • prefetch : <link rel="prefetch">则用于预取页面可能导航到的下一个页面的资源。这有助于在用户实际导航到该页面之前加载并缓存这些资源,从而减少页面加载时间。
  • PreconnectDNS-Prefetch: 这两个资源提示符分别用于建立早期TCP连接和解析DNS,以加快未来HTTP请求的响应速度。

如有错误,请指正O^O!

相关推荐
帅帅哥的兜兜30 分钟前
next.js实现项目搭建
前端·react.js·next.js
筱歌儿35 分钟前
css 左右布局
前端·css
GISer_Jing1 小时前
编译原理AST&以Babel为例进行解读、Webpack中自定义loader与plugin
前端·webpack·node.js
GISer_Jing1 小时前
Webpack中Compiler详解以及自定义loader和plugin详解
前端·webpack·node.js
浩~~1 小时前
CSS常用选择器
前端·css
于慨1 小时前
uniapp+vite+cli模板引入tailwindcss
前端·uni-app
yunvwugua__2 小时前
Python训练营打卡 Day26
前端·javascript·python
满怀10152 小时前
【Django全栈开发实战】从零构建企业级Web应用
前端·python·django·orm·web开发·前后端分离
Darling02zjh2 小时前
GUI图形化演示
前端
Channing Lewis2 小时前
如何判断一个网站后端是用什么语言写的
前端·数据库·python