两者都是用来异步加载js文件,提高网页性能。
1. async
1.2 使用场景
主要是不涉及操作DOM的事件,比如使用百度分析的脚本
1.1 与html解析、DOMContentLoaded的关系
情况1:HTML 还没有被解析完的时候,async脚本已经加载完了,那么 HTML
停止解析,去执行脚本,脚本执行完毕后触发DOMContentLoaded事件。
情况2: HTML 解析完了之后,async脚本才加载完,然后再执行脚本,那么在HTML解析完毕、async脚本还没加载完的时候就触发DOMContentLoaded事件。
1.3 综述
- 无论html是否解析完成,立即执行脚本;
- 无论有使用多少个async加载脚本,只要脚本下载完成,立即执行脚本。与<script>标签的顺序无关。
2. defer
2.1 使用场景
操作DOM的脚本,为防止元素尚未加载完成,脚本找不到元素报错。
2.2 html解析、DOMContentLoaded的关系
情况1:HTML还没解析完成时,defer脚本已经加载完毕,那么defer脚本将等待HTML解析完成后再执行。defer脚本执行完毕后触发DOMContentLoaded事件。
情况2: HTML解析完成时,defer脚本还没加载完毕,那么defer脚本继续加载,加载完成后直接执行,执行完毕后触发DOMContentLoaded事件。
2.3 综述
- 无论js文件是否下载完成,只有html解析完毕,才可以执行脚本;
- 脚本执行的顺序与下载的完成时间无关,按照<script>脚本的位置,顺序执行。
注: 图片来源网络。