1、var 声明的变量会挂载在 window 对象上,而 let 和 const 声明的变量不会
举例:
var a = '我是a';
console.log(a); // 打印结果:我是a
console.log(window.a); // 打印结果:我是a
let b = '我是b';
console.log(b); // 打印结果:我是b
console.log(window.b); // 打印结果:undefined
let c = '我是c';
console.log(c); // 打印结果:我是c
console.log(window.b); // 打印结果:undefined
var 的这一特性,会造成 window 全局变量的污染。举例如下:
var innerHeight = 100;
console.log(window.innerHeight); // 打印结果:永远都是100 ==> 会覆盖 window 自带的 innerHeight 属性
2、var 声明的变量存在变量提升,let 和 const 声明的变量不存在变量提升
举例:
console.log(a); // 打印结果:undefined ==> a已经声明但没有赋