<script src="script.js"></script>
浏览器
没有 defer
或 async
,浏览器会当即加载并执行指定的脚本,“当即”指的是在渲染该 script
标签之下的文档元素以前,也就是说不等待后续载入的文档元素,读到就加载并执行。网络
<script async src="script.js"></script>
异步
有 async
,加载和渲染后续文档元素的过程将和 script.js
的加载与执行并行进行(异步)。async
<script defer src="myscript.js"></script>
code
有 defer
,加载后续文档元素的过程将和 script.js
的加载并行进行(异步),可是 script.js
的执行要在全部元素解析完成以后,DOMContentLoaded
事件触发以前完成。事件
蓝色线表明网络读取,红色线表明执行时间,这俩都是针对脚本的;绿色线表明 HTML 解析。ip
此图告诉咱们如下几个要点:文档