defer和async
时间: 2024-04-25 11:22:48 浏览: 19
defer和async是用于控制脚本加载和执行时机的属性。它们的主要区别在于执行时机和脚本之间的依赖关系。
defer属性表示脚本的加载和执行是延迟的,即在HTML解析完毕后执行。它不会阻塞后续HTML的解析,但会按照脚本在HTML中的顺序执行。defer适用于需要保证脚本按照顺序执行的情况,因为它能够保证脚本之间的变量依赖关系。
async属性表示脚本的加载和执行是异步的,即在下载完成后立即执行。它也不会阻塞后续HTML的解析,但无法保证脚本的执行顺序,谁先下载完成谁先执行。因此,如果脚本之间存在依赖关系,不推荐使用async。
需要注意的是,async和defer都只适用于外联脚本,即通过src属性引入的脚本。它们不适用于内联脚本。
综上所述,通常情况下,defer的使用频率较高,它能够保证脚本之间的变量依赖关系。而async适用于独立的脚本,且不需要考虑脚本执行顺序的情况。
#### 引用[.reference_title]
- *1* *3* [详解defer和async的原理及应用](https://blog.csdn.net/liuhe688/article/details/51247484)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item]
- *2* [async和defer的区别?](https://blog.csdn.net/qq_44621394/article/details/126545273)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item]
[ .reference_list ]