javascript - JS 全局/函数作用域理解

标签 javascript global-variables scope hoisting

我目前正在参加 Javascript 类(class),我需要一些帮助来了解作用域的确切工作原理。我们已经讨论了全局范围、函数范围、类提升等主题,但我正在努力将它们放在一起。因此,我特别关注的问题包括弄清楚以下代码的输出内容:

x = 1;
var a = 5;
var b = 10;
var c = function (a, b, c) {
    document.write(x);
    document.write(a);
    var f = function (a, b, c) {
        b = a;
        document.write(b);
        b = c;
        var x = 5;
    }
    f(a, b, c);
    document.write(b);
    var x = 10;
}
c(8, 9, 10);
document.write(b); 
document.write(x);

现在我们的解决方案是代码将打印出 undefined 8 8 9 10 1

我需要一些帮助来了解这是如何发生的。具体来说,我不明白 b 的值如何根据我们正在查看的语句而变化。如果有人能为我完成整个步骤,我将不胜感激。 谢谢!

最佳答案

我对代码做了一些评论,希望它更有意义。要理解的最重要的概念是变量提升和函数作用域。 JavaScript 中只有函数作用域。

x = 1;
var a = 5;
var b = 10;
var c = function (a, b, c) {

    /* this `x` refers to the new `x` variable initialized below
     * near the closing function `c` brace.
     * It is undefined because of hoisting, and gets assigned
     * a value where it was initialized below.
     */
    console.log(x); // undefined

    /* this `a` refers to this `a` parameter,
     * because it is within this function `c` scope.
     */
    console.log(a);

    var f = function (a, b, c) {

        /* this `b` refers to this `b` parameter,
         * because it is within this function `f` scope.
         *
         * this `a` refers to this `a` parameter,
         * because it is within this function `f` scope.
         */
        b = a;
        console.log(b);

         /* this `b` still refers to `b` in this function `f` scope.
          *
          * this `c` refers to this `c` parameter,
          * because it is within this function scope.
          */
        b = c;

        /* this is a new `x` variable because it is
         * with this function `f` scope and there is no parameter `x`.
         */
        var x = 5;
    };

    /* these `a`, `b`, and `c` variables refer to
     * this function `c` parameters.
     */
    f(a, b, c); // f(5, 10, 10)
    console.log(b); // 9

   /* this is a new `x` variable because it is
    * with this function `c` scope and there is no parameter `x`.
    */
    var x = 10;
};

c(8, 9, 10);

/* `a`, `b`, `c`, and `x` have not been touched,
 * because the other `a`,`b`,`c` variables were parameter names,
 * and other `x` variables were initialized within a different scope.
 */
console.log(b); // 10 
console.log(x); // 1

<强> JSBin Demo

关于javascript - JS 全局/函数作用域理解,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28600279/

相关文章:

javascript - 为什么这个 "if"通过了,但实际上它不应该通过?

eclipse - 成员变量前缀错误地添加到方法名称

javascript - 在 XUL 组件之间发送数据

javascript - Handlebars 错误

javascript - 如何使用之后定义的变量推理提前返回

javascript - 如何操作对象原型(prototype)的属性?

c++ - 如何设置全局容器(C++03)?

r - 在 Shiny 中的用户 session 之间共享 react 数据集

python - 关于python变量作用域的疑惑

c++ - 如何赋予这个变量全局作用域