var
使用var声明的变量既是顶级变量(顶层对象(window对象)的属性也是全局变量)
通俗来说使用var关键字声明的变量都在window上
使用var声明的变量存在变量提升(提升变量声明)的情况
console.log(b) //undefined
var b =10
//上面的代码演化成下面的步骤 他不会报错 因为变量声明提升
var b;
console.log(b);
b=10
使用var可以对一个变量进行多次声明,后面的变量会覆盖前面的变量声明
在函数中再次使用var声明这个变量的时候,这个变量就是局部的如果不是用var,那就是全局的
var d=10
function fun(){
var d =20
}
fun()
console.log(d);//10
let
块级作用域
num只能存在于花括号里面
{
let num=10
}
console.log(num);//报错 num is undefined
let不存在变量提升
let不允许在相同的作用于下面重复声明
const
const 声明的是一个只读的常量,一旦声明,常量的值就不能改变
const一旦声明,就必须赋值
const 所声明的变量只在let命令所在的代码块中生效
const 不存在变量提升
const 不允许在相同的作用于下面重复声明
区别
1.1变量提升
var存在变量提升 let和const不存在变量提升
1.2块级作用域
var不存在块级作用域,let和const存在块级作用域,只在所在的代码块生效
1.3重复声明
var 可以重复声明,let和const不允许在同一个作用域中重复声明
1.4修改声明变量
var和let可以修改已经声明的变量,const不可以,一旦声明,必须赋值,并且常量的值不能改变