JavaScript hoisting and scope

断了今生、忘了曾经 提交于 2019-12-04 06:41:39

问题


why the foo() function logs undefined? The first text variable is a global variable so foo() should have an access to it.

var text = "outside";

function foo() {
    console.log(text);
    var text = "inside";
}

foo();

回答1:


Even though the var statement is after the console.log() statement, the declaration is hoisted to the beginning of the function. So this declares a local variable that shadows the global variable. But the initialization doesn't happen until you actually get to the statement, which is after the console.log() statement.

So your function is equivalent to:

function foo() {
    var text;
    console.log(text);
    text = 'inside';
}

If you didn't use the var declaration then you would continue to use the global variable, and the reassignment wouldn't happen until after the console.log().



来源:https://stackoverflow.com/questions/39396572/javascript-hoisting-and-scope

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!