async和defer

为什么要有async和defer

在html中加载脚本我们通常这么写

<script src="script.js"></script>

浏览器加载效果

这样写浏览器会立即加载并执行指定的脚本,缺点就是会阻塞html的加载来加载脚本,如果脚本很多的话,页面空白时间比较长,体验就很差。
所以我们需要想办法能不能避免这个情况,就有了async和defer。

概念

asyncdefer 都是script标签的属性。
带async

<script async src="script.js"></script>

浏览器会将HTML和脚本并行执行(异步)

带defer

<script defer src="myscript.js"></script>

脚本和HTML并行执行,但在HTML整个解析结束后才会去执行脚本

defer.png

在实际使用过程中我们都会将脚本标签放在</script> 之前,来保证其他元素的优先加载。

区别

1. 下载都是和HTML同步的。
2. async在下载完后就执行,defer在HTML解析完后再执行。
3. defer是按照加载顺序来执行脚本。
4. async不管声明的顺序,加载完就执行。

建议

在使用过程中要加载多个脚本文件的话,建议根据依赖关系来整理脚本的声明顺序。

参考

async vs defer attributes

defer和async的区别

script的defer和async

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 没有 defer 或 async,浏览器会立即加载并执行指定的脚本,“立即”指的是在渲染该 script 标签之下...
    饥人谷_Shirley阅读 965评论 0 0
  • async和defer 没有defer或者async,浏览器会立刻加载并执行脚本,“立即”指的是在渲染该scrip...
    mianmiani阅读 214评论 0 0
  • defer和async是script标签的两个属性,用于在不阻塞页面文档解析的前提下,控制脚本的下载和执行。先了解...
    小囧兔阅读 622评论 1 2
  • script标签一般会放到body标签的最后面也就是 之前,这样可以防止js文件的下载和执行阻塞html和css文...
    普莱那阅读 394评论 0 0
  • 行动吧,少年! 当我们已经列好了我们每天要做的事情的清单的时候,下一步就是开始行动吧。我们每天要做的事情很多,如何...
    宛若清风R阅读 156评论 0 0