Why do some variables declared using let inside a function become available in another function, while others result in a reference error?

前端 未结 8 1138
说谎
说谎 2021-01-30 03:45

I can\'t understand why variables act so strange when declared inside a function.

  1. In the first function I declare with let the variabl

相关标签:
8条回答
  • 2021-01-30 03:59

    Here are the 3 interesting aspects of variable declarations in JavaScript:

    1. var restricts the scope of variable to the block in which it is defined. ('var' is for local scope.)

    2. let allows temporary overriding of an external variable's value inside a block.

    3. Simply declaring a variable without var or let will make the variable global, regardless of where it is declared.

    Here is a demo of let, which is the latest addition to the language:

    // File name:  let_demo.js
    
    function first() {
       a = b = 10
       console.log("First function:    a = " + a)
       console.log("First function:    a + b = " + (a + b))
    }
    
    function second() {
        let a = 5
        console.log("Second function:    a = " + a)
        console.log("Second function:    a + b = " + (a + b))
    }
    
    first()   
    
    second()
    
    console.log("Global:    a = " + a)
    console.log("Global:    a + b = " + (a + b))
    

    Output:

    $ node let_demo.js 
    
    First function:    a = 10
    First function:    a + b = 20
    
    Second function:    a = 5
    Second function:    a + b = 15
    
    Global:    a = 10
    Global:    a + b = 20
    

    Explanation:

    The variables a and b were delcared inside 'first()', without var or let keywords.

    Therefore, a and b are global, and hence, are accessible throughout the program.

    In function named 'second', the statement 'let a = 5' temporarily sets the value of 'a' to '5', within the scope of the function only.

    Outside the scope of 'second()', I.E., in the global scope, the value of 'a' will be as defined earlier.

    0 讨论(0)
  • 2021-01-30 04:01

    Variables using the let keyword should only be available within the scope of the block and not available in an outside function...

    Each variable that you are declaring in that manner is not using let or var. You are missing a comma in the variables declaration.

    It is not recommended to declare a variable without the var keyword. It can accidentally overwrite an existing global variable. The scope of the variables declared without the var keyword become global irrespective of where it is declared. Global variables can be accessed from anywhere in the web page.

    function first() {
       let a = 10;
       let b = 10;
       let c = 10;
       var d = 20;
       second();
    }
    
    function second() {
       console.log(b + ", " + c); //shows "10, 10"
       console.log(a); //reference error
       console.log(d); //reference error
    }
    
    first();

    0 讨论(0)
  • 2021-01-30 04:01

    It's because of when you don't use let or var then variable is getting declare on the fly, better you declare like following.

    let a = 10;
    let b = 10;
    let c = 10;
    
    0 讨论(0)
  • 2021-01-30 04:05

    Before calling things strange, let’s know some basics first:

    var and let are both used for variable declaration in JavaScript. For example,

    var one = 1;
    let two = 2;
    

    Variables can also be declared without using var or let. For example,

    three = 3;
    

    Now the difference between the above approaches is that:

    var is function scoped

    and

    let is block scoped.

    while the scope of the variables declared without var/let keyword become global irrespective of where it is declared.

    Global variables can be accessed from anywhere in the web page (not recommended because globals can be accidentally modified).

    Now according to these concepts let's have a look at the code in question:

     function first() {
       let a = b = c = 10;
       /* The above line means:
        let a=10; // Block scope
        b=10; // Global scope
        c=10; // Global scope
        */
    
       var d = 20; // Function scope
       second();
    }
    
    function second() {
       alert(b + ", " + c); // Shows "10, 10" //accessible because of global scope
       alert(a); // Error not accessible because block scope has ended
       alert(d); // Error not accessible because function scope has ended
    }
    
    0 讨论(0)
  • 2021-01-30 04:13

    The strange issue is caused by scoping rules in JavaScript

    function first() {
       let a = b = c = 10; // a is in local scope, b and c are in global scope
       var d = 20; // d is in local scope
       second(); // will have access to b and c from the global scope
    }
    

    Assuming that you want to declare 3 local variables initialised to the same value (100). Your first() will look like below. In this case, second() will not have access to any of the variables because they are local to first()

    function first() {
       let a = 100; // a is in local scope init to 100
       let b = a; // b is in local scope init to a
       let c = b // c is in local scope init to b
    
       var d = 20; // d is in local scope
       second(); // will not have access a, b, c, or d
    }
    

    However, if you want global variables then your first() will look like below. In this case, second will have access to all the variables because they are in global scope

    function first() {
       a = 100; // a is in global scope
       b = a; // b is in global scope
       c = b // c is in global scope
    
       d = 20; // d is in global scope
       second(); // will have access to a, b, c, and d from the global scope
    }
    

    Local variables (aka. accessible in the code block where they are declared).
    A Code block is any {} with line(s) of code between.

    • function() {var, let, const in here is accessible to entire function},
    • for() {var in here is accessible to outer scope, let, const accessible only in here},
    • etc.

    Global variables (aka accessible in the global scope).
    These variables are attached to the global object. The global object is environment dependent. It is the window object in browsers.

    Special note: You can declare variables in JavaScript without using the var, let, const keywords. A variable declared this way is attached to the global object, therefore accessible in the global scope.
    a = 100 // is valid and is in global scope

    Some articles for further reading: https://www.sitepoint.com/demystifying-javascript-variable-scope-hoisting/ https://scotch.io/tutorials/understanding-scope-in-javascript https://www.digitalocean.com/community/tutorials/understanding-variables-scope-hoisting-in-javascript

    0 讨论(0)
  • 2021-01-30 04:15

    In the function first(), variables band c are created on the fly, without using var or let.

    let a = b = c = 10; // b and c are created on the fly
    

    Is different than

    let a = 10, b = 10, c = 10; // b and c are created using let (note the ,)
    

    They become implicit global. That's why they are available in second()

    From documentation

    Assigning a value to an undeclared variable implicitly creates it as a global variable (it becomes a property of the global object) when the assignment is executed.

    To avoid this, you can use "use strict" that will provide errors when one use an undeclared variable

    "use strict"; // <-------------- check this
    
    function first() {
       /*
        * With "use strict" c is not defined.
        * (Neither is b, but since the line will be executed from right to left,
        * the variable c will cause the error and the script will stop)
        * Without, b and c become globals, and then are accessible in other functions
        */
       let a = b = c = 10;
       var d = 20;
       second();
    }
    
    function second() {
       console.log(b + ", " + c); //reference error
       console.log(a); //reference error
       console.log(d); //reference error
    }
    
    first();

    0 讨论(0)
提交回复
热议问题