javascript - 为什么javascript在一个函数中而不是在另一个函数中从父作用域访问值?

标签 javascript scope

为什么第二个代码片段表现异常?

这个问题不同于Questions on Javascript hoisting ,因为这个问题包括一个 IIFE,一个局部作用域,并且是为了更好地理解父作用域。


这个函数输出正确

var one = 1;
function sayOne() {
    console.log(one); // actually gets the value from the global scope
}
sayOne();

输出:

1


但是这个没有。

var one = 1;
function sayDoom() {
    console.log(one); // somehow does not get the value from parent scope
    var one = 2;
    console.log(one);
    (function() {
        var one = 3;
        console.log(one); // displays correctly
    })();
}
sayDoom();

输出:

undefined
2
3

预期:

1
2
3

最佳答案

在 javascript 中,由于变量提升,如果你在变量声明之前引用它,它将返回 undefined

实际上代码变成这样

function sayDoom() {
    var one;               // global variable wont be accssible now
    console.log(one); // returns undefined
    one = 2;
    console.log(one);
    (function() {
        var one = 3;
        console.log(one); // displays correctly
    })();
}
sayDoom();

您可以在 sayDoom() 函数中使用 this.one 访问您的全局 one 变量

编辑如果你使用严格模式这不会工作

关于javascript - 为什么javascript在一个函数中而不是在另一个函数中从父作用域访问值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31764554/

相关文章:

javascript - 在 Wordpress 插件中包含 jQuery

javascript - 未终止的字符串 literal.ts(1002)

javascript - 将 Javascript 对象传递给 HTML iframe(作为对象)

c - 如何从函数修改堆指针

powershell - 在 Jenkins 构建的 Windows Powershell 中设置的变量,在其他构建步骤中不可用

python - 类定义中的变量范围令人困惑

javascript - IE8 绝对/相对定位元素不显示

javascript - 是否可以通过搜索插件正确使用导航键(热键插件)("show_only_matches": true)

javascript - 禁止选择属性为 "disabled"的选项

java - 如何将信息从 JFrame 传输到实例化它的方法?