• 技术文章 >web前端 >js教程

    JavaScript中var,let与const的区别是什么?

    青灯夜游青灯夜游2020-11-13 10:54:49原创1252

    区别:1、var声明的变量属于函数作用域,let和const声明的变量属于块级作用域;2、var存在变量提升现象,而let和const没有;3、var变量可以重复声明,而在同一块级作用域,let变量不能重新声明,const变量不能修改。

    推荐教程:《JavaScript视频教程

    在ES6(ES2015)出现之前,JavaScript中声明变量就只有通过 var 关键字,函数声明是通过 function 关键字,而在ES6之后,声明的方式有 var 、 let 、 const 、 function 、 class ,本文主要讨论 var 、 let 和 const 之间的区别。

    了解var

    如果使用关键字 var 声明一个变量,那么这个变量就属于当前的函数作用域,如果声明是发生在任何函数外的顶层声明,那么这个变量就属于全局作用域。举例说明:

    var a = 1; //此处声明的变量a为全局变量
    function foo(){
       var a = 2;//此处声明的变量a为函数foo的局部变量
       console.log(a);//2
    }
    foo();
    console.log(a);//1

    如果在声明变量时,省略 var 的话,该变量就会变成全局变量,如全局作用域中存在该变量,就会更新其值。如:

    var a = 1; //此处声明的变量a为全局变量
    function foo(){
       a = 2;//此处的变量a也是全局变量
       console.log(a);//2
    }
    foo();
    console.log(a);//2

    注意:var 声明的变量存在提升(hoisting)。

    了解“提升”

    提升是指无论 var 出现在一个作用域的哪个位置,这个声明都属于当前的整个作用域,在其中到处都可以访问到。注意只有变量声明才会提升,对变量赋值并不会提升。如下例所示:

    console.log(a);//undefined
    var a = 1;

    该代码段跟下列代码段是一样的逻辑:

    var a;
    console.log(a);//undefined
    a = 1;

    而如果对未声明过的变量进行操作,就会报错

    console.log(b);//假设b未声明过,Uncaught ReferenceError: b is not defined

    了解let

    let 声明的变量,具有如下几个特点:

    如下面几个例子所示

    let a = 1;
    console.log(a);//1
    console.log(b);//Uncaught ReferenceError: b is not defined
    let b = 2;
    function foo(){
        let a = 1;
        let a = 2;//Uncaught SyntaxError: Identifier 'a' has already been declared
    }

    以下是一个经典的关于 var 和 let 的一个例子:

    for (var i = 0; i < 10; i++) {
        setTimeout(function(){
            console.log(i);
        },100)
    };

    该代码运行后,会在控制台打印出10个10.若修改为:

    for (let i = 0; i < 10; i++) {
        setTimeout(function(){
            console.log(i);
        },100)
    };

    则该代码运行后,就会在控制台打印出0-9.

    了解const

    const 声明方式,除了具有 let 的上述特点外,其还具备一个特点,即 const 定义的变量,一旦定义后,就不能修改,即 const 声明的为常量。

    例如:

    const a = 1;
    console.log(a);//1
    a = 2;
    console.log(a);//Uncaught TypeError: Assignment to constant variable.

    但是,并不是说 const 声明的变量其内部内容不可变,如:

    const obj = {a:1,b:2};
    console.log(obj.a);//1
    obj.a = 3;
    console.log(obj.a);//3

    所以准确的说,是 const 声明创建一个值的只读引用。但这并不意味着它所持有的值是不可变的,只是变量标识符不能重新分配。

    区别总结

    更多编程相关知识,请访问:编程教学!!

    以上就是JavaScript中var,let与const的区别是什么?的详细内容,更多请关注php中文网其它相关文章!

    声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
    专题推荐:JavaScript var let const
    上一篇:typeof和instanceof的区别是什么 下一篇:JavaScript的三大组成部分是什么
    大前端线上培训班

    相关文章推荐

    • javascript中非常实用的10个特性• 了解JavaScript中的垃圾回收机制• 详细了解JavaScript中的延迟加载• JavaScript算法之归并排序算法(详解)• 详解javascript中逻辑运算符• javascript中的运算符有哪些

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网