首页 > 其他 > 详细

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

时间:2019-05-24 17:31:10      阅读:122      评论:0      收藏:0      [点我收藏+]

 

  

一   作用域

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

  var和let

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

  不同点: 

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

    {
        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 禁止重复声明变量  

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
}

  const

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

<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>

  

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

原文:https://www.cnblogs.com/ly-qingqiu/p/10919188.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!