一道很基础的 JS 面试题,但是 90% 的前端不知道怎么回答!

2,283 阅读2分钟

哈喽,大家好 我是 xy👨🏻‍💻。今天给大家分享一道面试题:JavaScript 运行是怎么运行的!

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

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

语法分析(Lexical Analysis):

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

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

例如,当遇到

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

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

  • var(关键字)

  • name(标识符)

  • =(赋值操作符)

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

  • ;(语句终结符)

预编译(Pre-compilation)

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

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

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

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

图片来源于网络

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

解释执行(Interpretation)

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

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

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

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

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

最后

如果觉得本文对你有帮助,希望能够给我点赞支持一下哦 💪 也可以关注wx公众号:前端开发爱好者 回复加群,一起学习前端技能 公众号内包含很多实战精选资源教程,欢迎关注