一、let声明变量
1.let声明的变量不会挂在window中,不会造成全局变量的污染!

2.新增了一个块级作用域{},以前只有函数作用域,全局作用域

3.let是不允许重复声明

4.let不会有声明提前(只是人为看到的效果,实际上是有声明提前,提前临时性的死区中:Cannot access ‘num’ before initialization)

二、var声明变量
1.存在变量提升机制,JS引擎遇到var声明,会将其声明提到作用域顶端。

2.覆盖全局对象存在的变量(造成全局污染)

关于let和var的区别,从最经典的i值的问题上就可以看出来

用var声明的i值输出总为10,想要解决这个问题在ES6以前有且只有一种方法,包裹一个函数,产生作用域。ES6后只需要使用let声明i就可以解决这个问题。
能这样解决的原因:
let声明的 i 是区块变量,每个 i 只能存活到大括号结束
var声明的 i 是局部变量,这个 i 的生命周期不会受for循环的大括号限制
三、const声明常量
1.跟let完全相同 增加几个点
2.不允许被修改(不允许改变内存空间的地址)

3.const声明和赋值必须一次性完成,并且后期不允许改变存储空间的地址

在大型公司中,对项目进行整改,将代码从ES5迁移到ES6,能使用const就使用const,不能使用就用let。常量的效率比变量要高。
本文深入探讨了ES6中let, var和const的使用区别,重点解析了它们的作用域、生命周期及性能特点,帮助读者理解如何更高效地使用这些关键字。
954

被折叠的 条评论
为什么被折叠?



