执行上下文(Execution Context)
执行上下文又称执行环境。JavaScript 在内部创建的全局作用域(Global Scope),大致等效于 var window = Window()
。浏览器打开 URL 时,会自动创建第一个执行上下文——全局作用域。
执行上下文是由一个包含变量定义和 this 对象绑定的域派生的。在一个给定的执行上下文中的 this 对象,本质上指向了其操作的对象上下文。
函数调用时会产生一个执行上下文,然后这个新创建的执行上下文会被放到调用栈(Execution Stack or Call Stack)栈顶。还有另外一种情况也会生成执行上下文,就是 new
构造函数实例化对象的时候。
无论你是调用函数还是实例化任何对象,都会创建新的执行上下文并将其入栈。重复此过程,同时一直保持 this 对象指向当前执行上下文(即栈顶的执行环境)。
JavaScript 中的执行环境可以分为三种。
- 全局环境:在浏览器中,全局环境被认为是 window 对象。因此,所有的全局变量和函数都作为 window 对象的属性和方法创建的。
- 函数环境:当一个函数执行时,就会创建该函数的执行环境,在其中执行代码。
- eval
函数内,没有使用 var 声明的变量,在非严格模式下为 window 的属性,即全局变量。
函数调用栈(call stack)
具体参考 MDN 术语解释
调用栈是解释器(比如浏览器中的 JavaScript 解释器)追踪函数执行流的一种机制。当执行环境中调用了多个函数时,通过这种机制,我们能够追踪到哪个函数正在执行,执行的函数体中又调用了哪个函数。
- 每调用一个函数,解释器就会把该函数添加进调用栈并开始执行。
- 正在调用栈中执行的函数还调用了其它函数,那么新函数也将会被添加进调用栈,一旦这个函数被调用,便会立即执行。