请问es6中let var const有什么区别?
网友回复
一、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定义的变量是常量,声明时必须赋值,但不允许重复赋值,如果定义的是引用类型,可以修改数据内部结构。