var, let, const三者之间的区别

 

  

一   做用域javascript

  js中有全局做用域和局部做用域两种,java

  var和let函数

  相同点:   都是用来声明变量spa

  不一样点: blog

   (1) var 是全局声明。 let是局部声明,只在声明的块中有效(块级做用域)ip

    {
        var a = 1;
        let b = 2;
        console.log(a);   //    1
        console.log(b)    //    2
    }
    console.log(a);       //     1
    console.log(b)        //     b is not defined

 

  

   (2)   var声明存在变量提高。   let 声明不存在变量提高作用域

    console.log(a);       //     undefined
    console.log(b)        //     Uncaught ReferenceError: Cannot access 'b' before initialization  初始化以前没法访问“b”

    var a = 1;
    let b = 2;

     (3)    let 禁止重复声明变量  it

function fn (){
   var a = 1;
   let a = 2;
   console.log(a); //SyntaxError
}

function fn (){
   let a = 1;
   let a = 2;
   console.log(a); //SyntaxError
}

function fn (a){
   let a = 2;
   console.log(a); //SyntaxError
}

  constio

   const用来定义常量,使用是必须初始化(即必须赋值),一样只能在块级做用域里访问,一旦设置了就不能在修改了(不可重复声明)console

<script type="text/javascript">
    // 块做用域
    {
        var a = 1;
        let b = 2;
        const c = 3;
        // c = 4; // 报错
        var aa;
        let bb;
        // const cc; // 报错
        console.log(a); // 1
        console.log(b); // 2
        console.log(c); // 3
        console.log(aa); // undefined
        console.log(bb); // undefined
    }
    console.log(a); // 1
    // console.log(b); // 报错
    // console.log(c); // 报错
 
    // 函数做用域
    (function A() {
        var d = 5;
        let e = 6;
        const f = 7;
        console.log(d); // 5
        console.log(e); // 6  
        console.log(f); // 7 
 
    })();
    // console.log(d); // 报错
    // console.log(e); // 报错
    // console.log(f); // 报错
</script>