JS中script脚本的执行顺序

JS中script脚本的执行顺序

在HTML中引入script脚本时,最普通的用法是直接引用,此时浏览器按顺序解析HTML,当解析到script的位置时,加载脚本并在加载完毕时立即执行脚本,在加载和执行的过程中会暂停HTML的解析。此种方法的问题是一旦因为某些原因导致脚本的加载时间过长,会影响页面的渲染,降低用户体验。所以在script标签中存在两个参数asyncdefer,可以控制脚本的加载和执行时间。

async

async表示异步,script标签中有async参数时,浏览器会在解析到此处时异步加载脚本,加载完毕后立即执行脚本,只有在执行脚本的时候才停止页面的渲染过程,此种脚本的加载不计入DOMContentLoaded事件统计,意味着脚本的执行与DOMContentLoaded事件的执行顺序没有关联。如果有多个async脚本,谁先加载完谁先执行

defer

script标签中有defer参数时,浏览器会在解析到此处时异步加载脚本,但是不会立即执行,而是等到文档解析渲染完毕之后再执行脚本。如果有多个defer脚本,则按照文档中的顺序执行,全部执行完毕才会触发页面的DOMContentLoaded事件
此篇文章参考了以下两篇文章,在此表示感谢

https://www.cnblogs.com/jiasm/p/7683930.html
https://www.cnblogs.com/echolun/p/12614056.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值