+
80
-

es6中let var const有什么区别?

请问es6中let var const有什么区别?

网友回复

+
0
-

、var声明的变量属于函数作用域;let 和 const 声明的变量属于块级作用域,不能跨函数访问;

、var存在变量提升现象,而 let 和 const 没有;

那么什么是变量提升呢

官方解释:JavaScript在工作时会先获取所有变量,然后再一行一行地执行代码。这就导致了所有变量声明的语句都会被提升到代码的最前面。这就是变量提升。 举个例子

<script>
    var a = 5;
    function fn(){
        a = 3;
        console.log(a)
        var a;
    }
    fn()
</script>

很简单的一段代码,最终输出的是3。函数内的a覆盖了外面的变量a,var a;并没有刷新a的值,因为真正在运行时的顺序应该是这样的

<script>
    var a = 5;
    function fn(){
        var a;
        a = 3;
        console.log(a)
    }
    fn()
</script>

我们可以看到,写在下面的声明a的语句被提前到了函数的最上面,所以最后输出的是函数内部的变量a而不是外面的a = 5,这就叫js的变量提升

、var变量可以重复声明,值可改变;在同一个块级作用域下:let变量不能重新声明;const定义的变量是常量,声明时必须赋值,但不允许重复赋值,如果定义的是引用类型,可以修改数据内部结构。

我知道答案,我要回答