javascript - 为什么全局定义的变量是未定义的?

标签 javascript global-variables local-variables hoisting

我这里有一个简单的函数和一个全局变量。

Why is myname undefined and not the string "global"?

var myname = "global"; // global variable
function func() {
    alert(myname); // "undefined"
    var myname = "local";
    alert(myname); // "local"
}
func();

是否无法引用在该函数范围之外定义的外部变量?在这个全局变量中...

我该如何解决这个问题,这样我就不会得到undefined来自全局变量?

最佳答案

您刚刚偶然发现了一个名为“提升”的 js“功能”

var myname = "global"; // global variable
function func() {
    alert(myname); // "undefined"
    var myname = "local";
    alert(myname); // "local"
}
func();

在此代码中,当您定义 func 时,编译器会查看函数体。它发现您正在声明一个名为 myname 的变量。

Javascript Hoists variable and function declarations, by moving the declaration to the top of the function.

由于提升,您的代码被重写为以下内容。

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();

这“覆盖”了全局变量。如果您想访问函数范围内的全局变量,请使用 this 关键字。

var myname = "global"; // global variable
function func() {
    var myname = "local";
    alert(this.myname); // "global"
    alert(myname); // "local"
}
func();

请注意,这仅适用于调用函数,而不适用于方法或构造函数,因为 this 关键字会根据您调用函数的方式更改其绑定(bind)的内容。

编辑:为了完整性

如果您想在任何上下文中访问全局变量(无论函数类型如何),请声明一个按照惯例您永远不会覆盖的全局变量。

var global = this; // in global scope.
var myname = "global";
var obj = {f: function () {
    var myname = "local";
    console.log(global.myname);
}};
obj.f(); // "global"

请注意,this 位于方法位置,并且 this 关键字直接引用 obj,因此没有定义 myname。

关于javascript - 为什么全局定义的变量是未定义的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30469755/

相关文章:

javascript - promise 所有并获得请求

java - 为什么在大多数开源 java 项目中局部变量没有被声明为 final?

java - 为什么 `var` 不能用于可以推断类型的非局部变量?

c++ - 如何避免全局变量和魔数(Magic Number)?

c - C 中多处定义的全局符号的内存分配

Python 错误 : global name Xis not defined

C++:全局变量与局部变量。用什么?

javascript - jQuery - 拖放克隆元素

javascript - Ramda 返回响应作为请求正文

javascript - jQuery动态表计算