你刚刚遇到了JavaScript中的“特性”——变量提升
var myname = "global";
function func() {
alert(myname);
var myname = "local";
alert(myname);
}
func();
在这段代码中,当你定义 func
时,编译器会查看函数体。它会发现你声明了一个名为 myname
的变量。
Javascript通过将声明移动到函数顶部来提升变量和函数的声明。
由于提升,您的代码被重写为以下形式。
var myname = "global"; // global variable
function func() {
var myname; //declare local variable and assign it undefined
alert(myname); // "undefined"
myname = "local"; // assign local var myname to "local"
alert(myname); // "local"
}
func();
这里所说的“Covers”是指覆盖全局变量。如果你想在函数范围内访问全局变量,请使用this
关键字。
var myname = "global";
function func() {
var myname = "local";
alert(this.myname);
alert(myname);
}
func();
注意,这仅适用于调用函数而不是方法或构造函数,因为
this
关键字会根据如何调用函数来更改其绑定方式。
编辑:为了完整性
如果您想在任何上下文中访问全局变量,而不管函数类型,则声明一个按照约定从不覆盖的全局变量。
var global = this;
var myname = "global";
var obj = {f: function () {
var myname = "local";
console.log(global.myname);
}};
obj.f();
请注意,这是在方法位置中,this
关键字直接指向obj,并且因此没有定义myname。