一、var声明的变量属于函数作用域;let 和 const 声明的变量属于块级作用域,不能跨函数访问;
二、var存在变量提升现象,而 let 和 const 没有;
那么什么是变量提升呢
官方解释:JavaScript在工作时会先获取所有变量,然后再一行一行地执行代码。这就导致了所有变量声明的语句都会被提升到代码的最前面。这就是变量提升。
举个例子
<script>很简单的一段代码,最终输出的是3。函数内的a覆盖了外面的变量a,var a;并没有刷新a的值,因为真正在运行时的顺序应该是这样的
var a = 5;
function fn(){
a = 3;
console.log(a)
var a;
}
fn()
</script>
<script>我们可以看到,写在下面的声明a的语句被提前到了函数的最上面,所以最后输出的是函数内部的变量a而不是外面的a = 5,这就叫js的变量提升
var a = 5;
function fn(){
var a;
a = 3;
console.log(a)
}
fn()
</script>
三、var变量可以重复声明,值可改变;在同一个块级作用域下:let变量不能重新声明;const定义的变量是常量,声明时必须赋值,但不允许重复赋值,如果定义的是引用类型,可以修改数据内部结构。
网友回复