script标签async和defer的区别及作用
本文最后更新于:2023年3月19日 晚上
本文转自:https://www.cnblogs.com/leungUwah/p/10798585.html
作用
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 中有 defer 属性时,脚本的加载过程和文档加载是异步发生的,等到文档解析完(DOMContentLoaded 事件发生)脚本才开始执行。
当 script 有 async 属性时,脚本的加载过程和文档加载也是异步发生的。但脚本下载完成后会停止 HTML 解析,执行脚本,脚本解析完继续 HTML 解析。
当 script 同时有 async 和 defer 属性时,执行效果和 async 一致。
本博客所有文章除特别声明外,均采用 CC BY-SA 4.0 协议 ,转载请注明出处!