JS 预编译代码实例分析

news/2024/11/29 22:17:09/文章来源:https://www.cnblogs.com/gupingan/p/18577692

了解 JavaScript 引擎在执行代码过程中所做的一些行为是非常必要的,这有助于我们在遇到莫名其妙的调用时,能够大致定位问题所在。在我学习了预编译的相关知识,并基于该文章,引用其中的一段代码,结合“变量提升”、“函数提升”的小示例,对其进行详细的分析,算是留作一份笔记巩固记忆、加深理解。

代码

console.log(a)
fn1(1)
var a = 123
console.log(a)var fn1 = () => {console.log(a)
}function fn1(a) {console.log(a)var a = 666console.log(a)function a() {}console.log(a)var b = function () {}console.log(b)function c() {}
}fn1(1)

错误的推导会让你认为上述代码的打印如下:

如果你判断首行报错,那么需要了解变量提升
或者你这样认为
undefined
undefined
666
[Function: a]
[Function: b]
123
undefined
666
[Function: a]
[Function: b]

实际上,上方的代码打印如下:

undefined
[Function: a]
666
666
[Function: b]
123
123

详细分析

1. 创建全局对象 GO

在全局执行上下文中,创建全局对象 GO

2. 加载当前 JS 文件

加载并解析当前的 JavaScript 文件。

3. 脚本语法分析

进行语法分析,确保代码没有语法错误。

4. 当前 JS 文件预编译

4-1. 查找变量声明
GO = {a: undefined
}
4-2. 查找函数声明(除了函数表达式)
GO = {a: undefined,fn1: function fn1(a) {}
}

5. 正常执行(执行到函数调用前)

console.log(a) // 打印 undefined
fn1(1) // 执行到这里了,小心,函数也有预编译,执行前一刻完成

6. 函数预编译

6-1. 创建活跃对象 AO
AO = {}
6-2. 查找变量和形参
AO = {a: undefined,b: undefined
}
6-3. 实参值和形参统一
AO = {a: 1,b: undefined
}
6-4. 查找函数(非函数表达式)
AO = {a: function a() {},b: undefined,c: function c() {}
}

7. 正常执行函数(根据 AO)

console.log(a)  // 打印 function a() {}
var a = 666  // a 改变,AO.a = 666
console.log(a)  // 打印 666
function a() {}  // 该声明已提升过,不会覆盖
console.log(a)  // 打印 666
var b = function () {}  // b 改变,AO.b = function () {}
console.log(b)  // 打印 function () {}
function c() {}  // 该声明已提升过,不会覆盖

8. 接着执行函数外代码,执行到下个函数调用前

fn1(1) // 已讲述,上续
var a = 123  // GO 对象中的 a 改变为 123(undefined > 123)
console.log(a)  // 打印 123var fn1 = () => {  // fn1 改变,GO.fn1 = () => {...}console.log(a)
}function fn1(a) {  // 该声明已提升过(函数提升),不会覆盖...
}fn1(1)  // 执行到这里时,预编译

9. 函数预编译

9-1. 创建活跃对象 AO
AO = {}
9-2. 查找变量和形参
AO = {a: undefined
}
9-3. 实参值和形参统一
AO = {a: 1
}
9-4. 查找函数(非函数表达式)
AO = {a: 1
}

10. 正常执行函数(根据 AO)

console.log(a)  // a 不存在当前函数作用域,往上级查找,找到 GO.a,打印 123

总结

  • 全局预编译:创建 GO 对象,查找变量声明和函数声明。
  • 函数预编译:创建 AO 对象,查找变量和形参,实参值和形参统一,查找函数声明。
  • 执行阶段:按照代码顺序执行,变量赋值和函数调用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/843706.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

E. Photoshoot for Gorillas(Codeforces Round 966 (Div. 3))

https://codeforces.com/contest/2000/problem/E 题目描述 你非常喜欢屮大猩猩,于是你决定为它们组织一次拍摄活动。大猩猩生活在丛林中,丛林被表示为一个有 n 行 m 列的网格,有 w 个大猩猩同意参与拍摄,第 i 个大猩猩的身高ai .你希望将所有大猩猩放置在网格的单元格中,并…

windows版lammps的安装和计算

1.安装:详情见:https://mp.weixin.qq.com/s/xwx0c2ATNM0pphaHwDLkmQ 2.提交计算task的命令: mpiexec -np 4 lmp -in xxx.in #其中xxx.in表示in文件的名称,详情见 https://mp.weixin.qq.com/s/i6fa7xTKjlgSirPm0cj_4w 3.将MS的car和mdf文件导出data文件的方法:(命令…

第三十八讲:自增主键为什么不是连续的

你现在可以不懂,但以后面试的时候,必须要知道的三个关于自增主键的点 第一:唯一键冲突和事务回滚是导致自增主键不连续的两种大原因,此外批量插入数据的语句,MySQL 批量申请自增 id 的策略也是一个隐藏原因 第二:MySQL设计中不允许自增值回退的原因,主要是为了提升性能还…

NOIP 2024 退役记

人生有梦,各自精彩。Day -??? 摆疯了,啥也没复习,猫国建设者真好玩。 Day 0 昨晚回家结果摆到两点,感觉要在 noip 考场上睡着了/shui。早上没起来,迟到了/kk。 上午没怎么复习,摆摆摆,哎哎哎。 中午疯狂看小说,败犬太好看辣! 下午出发淄博。路上一直在睡觉,后悔没…

MySQL底层概述—4.InnoDB数据文件

大纲 1.表空间文件结构 (1)表空间Tablesapce (2)段Segment (3)区Extend (4)页Page (5)行Row 2.Page结构 (1)页结构各部分说明 (2)页结构整体划分 3.行记录格式 (1)行格式分类 (2)COMPACT行记录格式 (3)Compact中的行溢出机制 (4)其他行格式记录1.表空间文件结构 (1)表空间Table…

gin

Gin Gin入门 gin的学习要点如何定义路由:包括参数路由、通配符路由 如何处理输入输出 如何使用middleware解决AOP问题在 Gin 里面,用 Engine 来监听一个端口,是一个逻辑上的服务器。 一个 Go 进程可以创建多个 Engine。 hello, world 使用步骤:在应用中引入 Gin 依赖:go g…

MySQL底层概述—3.InnoDB线程模型

大纲 1.InnoDB的线程模型 2.IO Thread 3.Purge Thread 4.Page Cleaner Thread 5.Master Thread1.InnoDB的线程模型 InnoDB存储引擎是多线程的模型,因此其后台有多个不同的后台线程,负责处理不同的任务。后台线程的作用一:负责刷新内存池中的数据,保证缓冲池中的内存缓存是最…

20222427 2024-2025-1 《网络与系统攻防技术》实验七实验报告

1.实验内容 1.1 本周学习内容本周学习了有关Web安全的相关知识,复习了一些有关于Web的基础知识,比如:前、后端的定义,以及在前后端各自使用的语言,如:html、css、JS(前端);C/C++、Python、Java、Go、Php(后端)等。学习了有关于数据库攻击的一些基本操作,如:SQL注入…

基于Java+SpringBoot+Mysql实现的点卡各种卡寄售平台功能设计与实现四

部分功能:实名认证信息数据层Dao、银行卡类型信息数据层Dao、卡种类信息数据层Dao、卡类型信息数据层Dao、卡面值信息数据层Dao一、前言介绍: 免费学习:猿来入此 1.1 项目摘要 随着电子商务和在线支付技术的快速发展,数字商品和虚拟货币的交易需求日益增长。点卡及各种卡类…

kafka的搭建与使用

官网下载地址https://kafka.apache.org/downloads1、上传解压tar -zxvf kafka_2.11-1.0.0.tgz -C ../ mv kafka_2.11-1.0.0 kafka-1.0.02、修改环境变量 配置环境变量vim /etc/profileexport KAFKA_HOME=/usr/local/soft/kafka-1.0.0 export PATH=$PATH:$KAFKA_HOME/binsource …

河北公需课代 (可以补)

学时30个,需要联系15689397956