script标签async和defer的区别及作用

Posted leunguwah

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了script标签async和defer的区别及作用相关的知识,希望对你有一定的参考价值。

作用:

1.没有 defer 或 async,浏览器会立即加载并执行指定的脚本,也就是说不等待后续载入的文档元素,读到就加载并执行。

2.async 属性表示异步执行引入的 javascript,与 defer 的区别在于,如果已经加载好,就会开始执行——无论此刻是 html 解析阶段还是 DOMContentLoaded 触发之后。需要注意的是,这种方式加载的 JavaScript 依然会阻塞 load 事件。换句话说,async-script 可能在 DOMContentLoaded 触发之前或之后执行,但一定在 load 触发之前执行。

3.defer 属性表示延迟执行引入的 JavaScript,即这段 JavaScript 加载时 HTML 并未停止解析,这两个过程是并行的。整个 document 解析完毕且 defer-script 也加载完成之后(这两件事情的顺序无关),会执行所有由 defer-script 加载的 JavaScript 代码,然后触发 DOMContentLoaded 事件。

区别

defer 与相比普通 script,有两点区别:载入 JavaScript 文件时不阻塞 HTML 的解析,执行阶段被放到 HTML 标签解析完成之后。
在加载多个JS脚本的时候,async是无顺序的加载,而defer是有顺序的加载。

以上是关于script标签async和defer的区别及作用的主要内容,如果未能解决你的问题,请参考以下文章

理解JS中script标签defer和async属性

script标签中defer和async属性的区别

script标签中defer和async属性的区别

script标签中defer和async有什么不同?

script的defer和async的区别。

script标签中defer和async有什么不同?