一道很基础的 JS 面试题,但 90% 的前端不会答。。

程序员鱼皮

共 1705字,需浏览 4分钟

 ·

2024-06-13 14:29

分享一道经典前端面试题:JavaScript 是怎么运行的?

JavaScript 的运行过程可以被分解为几个关键步骤,其中包括语法分析预编译解释执行

下面是对这三个步骤的详细讲解!

语法分析(Lexical Analysis):

语法分析是 JavaScript 引擎处理代码的第一步。

在这个阶段,引擎将源代码字符串分解成一个个的词素(token),这些词素是语言中有意义的最小单元,如关键字变量名操作符等。

例如,当遇到

var name = '前端开发爱好者';

这样的语句时,语法分析器会将其分解为

  • var(关键字)

  • name(标识符)

  • =(赋值操作符)

  • 前端开发爱好者(字符串字面量)

  • ;(语句终结符)

预编译(Pre-compilation)

预编译是语法分析之后的一个阶段,这个阶段主要进行作用域链的建立和变量提升

JavaScript 引擎会创建一个作用域链,确保变量和函数的访问遵循正确的作用域规则。

变量提升是 JavaScript 中一个独特的特性,它指的是变量函数声明会被提升到它们所在作用域的顶部。

例如,即使在代码中后面声明了变量,引擎也会在预编译阶段将它们提升到顶部,但只有声明部分被提升,初始化部分不会。

图片来源于网络

另外,预编译阶段还会进行一些静态错误检查,比如检查变量是否已经声明。

解释执行(Interpretation)

解释执行是 JavaScript 代码实际运行的阶段。在这个阶段,JavaScript 引擎逐行读取代码,并根据代码的指令执行相应的操作。

解释器会逐个处理词素,将其转换成可执行的机器指令。这个过程可能涉及到变量的查找函数的调用表达式的计算等。

JavaScript 的解释执行通常比较慢,因为它需要在运行时动态地解析和执行代码。

为了提高性能,现代浏览器的 JavaScript 引擎通常会使用一些优化技术,如即时编译(JIT)编译器,将热点代码(频繁执行的代码)编译成机器码以提高执行效率。

这三个步骤共同构成了 JavaScript 代码的执行流程。值得注意的是,现代 JavaScript 引擎可能还会使用其他技术,如优化的解析器、字节码、JIT 编译等,以提高代码的执行效率。



👇🏻 点击下方阅读原文,获取鱼皮往期编程干货。

往期推荐

练习两年半,我们的项目更丰富啦!

当面试被问到分布式事务,就这样答!

说说我最近筛简历和面试的感受

我们的小程序每天早上都白屏,真相是。。。

被 Bug 折磨疯后,我写了本 Bug 修复手册。

用户破万了!

鱼皮的 Java 学习路线《速览版》

浏览 243
1点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
1点赞
评论
收藏
分享

手机扫一扫分享

分享
举报