浏览器中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事件->等待异步事件驱动触发

相关推荐
I'm Jie8 小时前
深入了解 Vue 3 组件间通信机制
前端·javascript·vue.js
用户90443816324609 小时前
90%前端都踩过的JS内存黑洞:从《你不知道的JavaScript》解锁底层逻辑与避坑指南
前端·javascript·面试
暮乘白帝过重山10 小时前
ArkTS ForEach 参数解析:组件与键值生成器
开发语言·数据库
PPPPickup10 小时前
easychat项目复盘---获取联系人列表,联系人详细,删除拉黑联系人
java·前端·javascript
老前端的功夫10 小时前
前端高可靠架构:医疗级Web应用的实时通信设计与实践
前端·javascript·vue.js·ubuntu·架构·前端框架
LiamTuc10 小时前
Java构造函数
java·开发语言
三途河畔人10 小时前
Pytho基础语法_运算符
开发语言·python·入门
Benmao⁢10 小时前
C语言期末复习笔记
c语言·开发语言·笔记·leetcode·面试·蓝桥杯
adsadswee10 小时前
Qt 样式与 QLinearGradient 渐变详解
开发语言·qt·qt样式表·qlineargradient·qss渐变效果
花月C11 小时前
个性化推荐:基于用户的协同过滤算法
开发语言·后端·算法·近邻算法