我正在尝试了解 JavaScript 范围规则。我在教科书和文档中读到的内容令人困惑。
在我看来,JavaScript 是一种静态(或词法)范围的语言 - 当试图将变量名绑定到变量(定义)时,会使用代码的词法结构。
执行上下文似乎类似于调用堆栈上的堆栈帧。每个执行上下文都有一个变量对象,所有局部变量(相关函数的)都在该变量对象上定义。这些变量对象链接在一起以提供从堆栈顶部的变量对象到堆栈底部的变量对象(窗口对象)的“范围链”。在将变量名称绑定到变量时,从上到下搜索此范围链。这与 C/C++/Java 等静态范围语言非常相似。
与 C/C++/Java 相比,似乎有一个重要的区别——可以访问在堆栈帧不再位于调用堆栈上的函数中定义的变量,如下例所示:
var color = "red";
var printColor;
function changeColor() {
var color = "green";
printColor = function(msg) {
alert(msg + color);
}
printColor("in changeColor context, color = "); // "green"
}
changeColor();
// stack frame for "changeColor" no longer on stack
// but we can access the value of the variable color defined in that function
printColor("in global context, color = "); // "green"
我做对了吗?还有其他我应该注意的问题吗?
提前致谢