defer的用途是代表脚本在执行时不会影响页面的构造。也就是说,脚本会延迟到整个页面都解析完毕后再运行。所以,在<script>元素中设置defer属性,至关于告诉浏览器当即下载,但延迟执行。浏览器
async属性与defer属性相似,都用于改变处理脚本的行为。建议异步脚本不要在加载期间修改DOM。网络
defer与async的区别是:前者要等到整个页面正常渲染结束,才会执行;后者一旦下载完,渲染引擎就会中断渲染,执行这个脚本之后,再继续渲染。一句话,defer是“渲染完再执行”,async是“下载完就执行”。另外,若是有多个defer脚本,会按照它们在页面出现的顺序加载,而多个async脚本是不能保证加载顺序的。异步
1. <script src="script.js"></script>async
没有 defer 或 async,浏览器会当即加载并执行指定的脚本,“当即”指的是在渲染该 script标签之下的文档元素以前,也就是说不等待后续载入的文档元素,读到就加载并执行。spa
2. <script async src="script.js"></script>blog
有 async,加载和渲染后续文档元素的过程将和 script.js 的加载与执行并行进行(异步)。事件
3. <script defer src="myscript.js"></script>ip
有 defer,加载后续文档元素的过程将和 script.js 的加载并行进行(异步),可是 script.js 的执行要在全部元素解析完成以后,DOMContentLoaded 事件触发以前完成。文档
蓝色线表明网络读取,红色线表明执行时间,这俩都是针对脚本的;绿色线表明 HTML 解析。渲染
此图告诉咱们如下几个要点: