微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

javascript – 为什么这个奇怪的行为?

参见英文答案 > Why is my global variable shadowed before the local declaration?3
我正在以3种方式修改一段代码.在这3个条件下行为不同.请描述它是如何执行的?
var a=1;
function myFunc(){
    console.log(a);
    console.log(a)
}
myFunc();
//Output is:
1 
1

var a=1;
function myFunc(){
    console.log(a);
    var a=2;
    console.log(a)
}
myFunc();
//Output is:
undefined
2

var a=1;
function myFunc(){
    console.log(a);
    var a=2;
    console.log(a)
}
myFunc(a);
//Output is:
undefined
2

为什么在第二种情况下打印未定义?在第三种情况下,我发送我的全局作为一个参数,那么它也是打印未定义的.

解决方法

这是因为JavaScript将var声明移动到范围的顶部,因此您的代码实际上是:
var a = 1;
function myFunc(){
    var a;            // a is redeclared,but no value is assigned
    console.log(a);   // therefore it evaluates to undefined
    a = 2;            // Now a = 2
    console.log(a);   // and then it logs to 2
}
myFunc();

这个行为叫做Variable Hoisting.

编辑
正如Beterraba所说,在第三个代码中,它记录未定义,因为在函数的头中没有声明参数:

var a = 1;
function myFunc(a) {    // a is declared
    console.log(a);     // Now a logs 1
    var a = 2;          // Now a = 2
    console.log(a);
}
myFunc(a);

原文地址:https://www.jb51.cc/js/155658.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐