浏览器中javascript时间线,从加载到执行

浏览器中javascript时间线,从加载到执行

javascript标签

作用

用来给HTML文档中引入javascript代码。

用法

1、通过<script>标签的src属性引入javascript文件;

2、通过<script>标签包裹javascript代码;

具体

模块化与非模块化

1、非模块化:没有通过type="module"修饰的,通过src引入的js代码,这些代码会加载完后,从上到下依次执行;

2、模块化:通过type="module"修饰,在js加载阶段,会将内部模块的所有静态相关依赖递归加载,按需加载完成后,从上到下依次执行;

同步加载

在HTML解析期间,遇到同步js加载,那么HTML解析会阻塞,在同步加载的代码中,可以通过document.write方法给HTML追加Text;

异步加载

通过给<script>标签设置async或defer实现异步加载,当同时设置这两个属性时,会以async为准。

async属性

设置async属性后,会在HTML解析期间正常加载js,并且不会阻塞HTML解析,并且在这期间加载完就会执行,所以执行顺序和加载顺序不一定相同;

defer属性

设置defer属性后,也会异步加载js,但是会在HTML解析完成后再执行,执行顺序与代码中的加载顺序一致;

客户端javascript时间线

HTML文档解析,readyState为loading->加载执行同步js脚本,HTML解析器暂停->加载async/defer属性值的js脚本,不影响HTML解析->文档解析完毕,readyState为interactive->Document对象派发DOMConnectLoaded事件,程序执行从同步脚本执行阶段过渡到异步事件驱动阶段->等待异步脚本执行以及资源加载完成,readyState变为complete,浏览器派发load事件->等待异步事件驱动触发

相关推荐
沐知全栈开发11 小时前
Perl 数据库连接
开发语言
森叶12 小时前
Java 比 Python 高性能的原因:重点在高并发方面
java·开发语言·python
qq_3168377512 小时前
uni.chooseMedia 读取base64 或 二进制
开发语言·前端·javascript
方圆工作室12 小时前
【C语言图形学】用*号绘制完美圆的三种算法详解与实现【AI】
c语言·开发语言·算法
小二·12 小时前
Python Web 开发进阶实战:混沌工程初探 —— 主动注入故障,构建高韧性系统
开发语言·前端·python
Lkygo12 小时前
LlamaIndex使用指南
linux·开发语言·python·llama
进阶小白猿12 小时前
Java技术八股学习Day20
java·开发语言·学习
gis开发12 小时前
【无标题】
java·前端·javascript
代码村新手13 小时前
C++-类和对象(中)
java·开发语言·c++
梦因you而美13 小时前
XPath 元素定位全方位技术文档
javascript·xpath·xpath定位