async和defer属性的区别

async和defer是HTML中<script>标签的两个属性,用于控制外部JavaScript脚本的加载和执行方式。defer属性使得脚本在页面解析完成后按顺序执行,而async属性则允许脚本异步加载,不保证执行顺序。使用defer和async可以优化页面加载性能,避免阻塞DOM构建。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<script>标签中存在两个相似的属性asyncdefer,这两者有什么区别呢?

推迟执行脚本

浏览器遇到定义了defer属性的script脚本时会立即下载,但是等整个页面都解析完后才执行,也就是推迟脚本的执行。脚本推迟执行了,但是依旧按照标签出现的顺序执行,即第一个推迟脚本会在第二个推迟脚本之前执行,第二个推迟脚本会在第三个推迟脚本之前执行。defer属性只对外部脚本文件有效。

异步执行脚本

浏览器遇到定义了 async属性的脚本时,会异步加载脚本文件,即不会阻塞页面的解析渲染,当脚本文件下载完毕后会立即执行并阻塞页面的解析。如果有多个被async标注的脚本文件,那么并不能保证脚本文件会按照出现的顺序执行,即第二个出现的脚本可能会比第一个先执行。同样async属性只对外部脚本文件有效。 给脚本添加async属性是为了告诉浏览器,不必等脚本下载和执行完后再加载页面,同样也不必等到该异步脚本下载和执行后再加载其他脚本。正因为如此,异步脚本不应该在加载期间修改DOM。
可以用一张图形象对比这两个属性的区别:
在这里插入图片描述用图表示会更容易理解一点。

deferasync是用于控制脚本加载执行时机的属性。它们的主要区别在于执行时机脚本之间的依赖关系。 defer属性表示脚本的加载执行是延迟的,即在HTML解析完毕后执行。它不会阻塞后续HTML的解析,但会按照脚本在HTML中的顺序执行。defer适用于需要保证脚本按照顺序执行的情况,因为它能够保证脚本之间的变量依赖关系。 async属性表示脚本的加载执行是异步的,即在下载完成后立即执行。它也不会阻塞后续HTML的解析,但无法保证脚本的执行顺序,谁先下载完成谁先执行。因此,如果脚本之间存在依赖关系,不推荐使用async。 需要注意的是,asyncdefer都只适用于外联脚本,即通过src属性引入的脚本。它们不适用于内联脚本。 综上所述,通常情况下,defer的使用频率较高,它能够保证脚本之间的变量依赖关系。而async适用于独立的脚本,且不需要考虑脚本执行顺序的情况。 #### 引用[.reference_title] - *1* *3* [详解deferasync的原理及应用](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* [asyncdefer区别?](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 ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值