客户端js的时间线:
1、web浏览器创建Document对象,开始解析html和文本、生成Element对象和Text节点添加到文档中。这个阶段的document.readystate=="loading"
2、当遇到没有async和defer的script标签时,停止文档的解析,开始请求并执行js
3、当遇到有async或defer时,会先下载js,但不执行,等到文档解析完毕之后才执行
4、当文档解析完成时,document.readyState=="interactive"
5、开始执行defer或async的脚本
6、浏览器在Document对象上触发DOMContentLoaded事件(此时异步的脚本可能尚未执行完毕)
7、当所有的资源都加载完成,并且所有的异步脚本也执行完成之后,document.readyState=="complete",此时在window对象上触发load事件