Js is a weakly typed language, so when declaring variables, you do not need to specify the type of variables, but use the same keyword.

var x = 18; 
y = "abc";
Copy the code

Declared variables and undeclared variables

Check method: Whether to use var(let const).

1. The scope of declared variables is limited to the context in which they are declared, and non-declared variables are always global.

function x() {
     y = 1; 
     var z = 2;
}
x();
console.log(y); // Prints '1',y is a non-declared variable - global.
console.log(z); // Raise ReferenceError: z is not declared outside x
Copy the code

2. Declare variables **(undefined)** is declared before any code is executed, whereas non-declared variables are defined only when an assignment is performed.

console.log(a1); // Print 'undefined' or '' (different browsers implement different)
var a1 = 1;

console.log(a2); / / throw ReferenceError
a2 = 1;
Copy the code

var hoisting

Since variable declarations are always processed before any code executes, declaring variables anywhere in the code is always equivalent to declaring them at the beginning of the code. This means that variables can be used before they are declared, an action called variable claim promotion.

You can’t do this in Java.

bla = 2;
var bla;

// can be used as an example
var bla;
bla = 2;
Copy the code

For this reason, we recommend declaring variables at the very beginning of the scope (at the beginning of a function or global code) to make the scope of the variable clear.

Otherwise, variables declared at the bottom are promoted to the beginning, which is error-prone.

 var v = "hello";
 def(v);
 function def(){
    alert(v);
    var v = "i love you";
 }
/ / the output: undefined
Copy the code

Variable declaration keyword

Although weakly typed, JavaScript has three variable modifiers: const let var. They differ in the scope of the declared variable.

var

The scope of the variable declared with the var statement:

1. When a variable is declared inside a function, the scope is inside the current function.

2. When a variable is declared outside a function, the scope is global.

let

The let statement declares a block-scoped local variable: scoped to the nearest {} of the current variable.

JavaScript’s scope requirements

1.. Redefining a variable with let in the same scope raises TypeError, and var overrides the previous variable.

2. Adopt the proximity principle when variables with the same name exist in different scopes:

Use the declaration if a variable of the same name exists in the current domain, or look up the nearest scope variable if it does not.

After grasping the scope of the two scopes, the nearest principle can be used to analyze.

function varTest() {
    var x = 1;
    if (true) {
        // Both x's are in the same scope, var overwrites
        var x = 2; 
		console.log(x); / / 2
     }
    console.log(x); / / 2
}

function letTest() {
    let x = 1;
    if (true) {
        // For let, the two x's are fundamentally in different scopes, using the proximity principle
        let x = 2; 
        console.log(x); / / 2
    }
    console.log(x); / / 1
}
letTest();

var x = 1;
function varTest() {
    if (true) {
        // Now the two X's are scoped differently: the first X is a global variable, while the second X is a variable in the method scope.
		var x = 2; 
		console.log(x); / / 2
    }
}
varTest();
console.log(x); / / 1
Copy the code

const

This declaration creates a constant that can be declared in a global scope or inside a function. The constant needs to be initialized. That is, constants must be initialized at the same time they are defined (this makes sense, since the value of a constant cannot be changed after initialization).

Constants have block scope, much like variables defined using let. The value of a constant cannot be changed by reassignment, nor can it be redeclared.

Implicit global variable and external function scope

// x is global
var x = 0;
function f(){
     //y is an implicit global variable,
    var x = y = 1;	
    console.log(x); //1 where x is a variable in the scope of the function, it does not affect the external
}
f();
console.log(x, y); / / 0, 1
Copy the code