我的头衔几乎概括了这一切。
谁能启发我…
“ JavaScript中的“执行上下文”是什么?”
以及它与“ this”,吊装,原型链,作用域和垃圾收集之间的关系?
您要问的是几个密切相关的不同概念。我将尝试简要地解决每个问题。
执行上下文 是语言规范中的一个概念,用外行的术语来说,大致等同于函数执行的“环境”。也就是说,变量作用域(以及 作用域链 ,外部作用域的闭包中的变量),函数参数和this对象的值。
this
该 调用堆栈 是执行上下文的集合。
范围 从字面上说是:可以访问变量的范围。简单地说:
var x; function a() { var y; }
x可以从任何地方访问。何时a调用,x将在外部范围内。(存储在 范围链中 。)
x
a
相反,y只能通过代码访问,a()因为它限于a的范围。这是什么var关键词呢:限制在局部范围的变量。如果我们省略var,y将最终出现在 全局范围内 ,通常被认为是一件坏事。
y
a()
var
将 吊装 更多地视为编译时的事情。在JavaScript中,函数 声明 “悬挂”在其作用域的顶部。换句话说,它们是在分析任何其他代码 之前 进行解析和评估的。(这与以内联方式求值的函数 表达式 相反。)请考虑以下几点:
a(); b(); function a() { } var b = function() { }
对to的调用a()将成功,因为其声明已被置于最高位置;a在程序开始执行之前被自动分配给。到的调用b()将失败,TypeError因为b直到第4行才会定义。
b()
TypeError
b