let也不允许同一块作用域中出现冗余声明(var可以):
1 2 3 4 |
|
此外,对声明冗余报错不会因混用var和let而受影响。这两个关键字声明的并不是不同类型的变量,他们只是指出变量在相关作用域如何存在。
2.1.暂时性死区
let与var的另一个重要区别是let声明的变量不会在作用域中被提升:
1 2 3 4 5 6 7 |
|
2.2.全局声明
与var不同,使用let在全局作用域中声明的变量不会成为window对象的属性(var声明的变量则会):
1 2 3 4 5 |
|
不过,let声明仍然是在全局作用域中发生的,相应变量会在页面的声明周期内存续。
2.3.条件声明
let的作用域是块,所以不可能检查前面是否已经使用let声明过同名变量,同时也就不可能在没有声明的情况下声明它。使用try/catch或typeof操作符也不能解决,因为条件块中let声明的作用域仅限于该块。为此,对于let这个新的ES6声明关键字不能依赖条件声明模式。
2.4.for循环中的let声明
在使用var的时候,最常见的问题就是对迭代变量的奇特声明和修改:
1 2 3 4 5 |
|
在退出循环的时候迭代变量保存的是导致循环退出的值:5。在之后执行setTimeout
超时逻辑时,所以i都是同一个变量,因而最终输出的都是同一个值。
使用let声明迭代变量时,JavaScript引擎在后台会为每个迭代循环声明一个新的迭代变量,每个setTimeout
引用的都是不同的变量实例:
1 2 3 4 |
|
【相关推荐:javascript学习教程】
3.const声明
const的行为与let基本相同,唯一一个重要区别是它声明变量时必须同时初始化变量,且尝试修改const声明的变量会导致运行错误。
const声明的限制只适用于它指向的变量的引用。如果const变量引用的是一个对象,那么修改这个对象内部的属性并不违反const的限制:
1 2 |
|
4.使用建议
let和const是ES6中新增的,从客观上为JavaScript更精确地声明作用域和语义提供更好的支持。
4.1.不使用var
限制自己只使用let和const有助于提升代码质量,因为变量有了明确的作用域、声明位置,以及不变的值。
4.2.const优先,let次之
使用const声明可以让浏览器运行时强制保持变量不变,也可以让静态代码分析工具提前发现不合法的赋值操作。因此,我们应该优先使用const来声明变量,只有在提前知道未来会有修改时再使用let。
更多编程相关知识,请访问:编程入门!!
以上就是javascript中声明变量的关键字是什么的详细内容,更多文章请关注木庄网络博客!
相关阅读 >>
vue.js中v-html渲染的dom添加scoped的样式的方法介绍
更多相关阅读请进入《javascript》频道 >>

Vue.js 设计与实现 基于Vue.js 3 深入解析Vue.js 设计细节
本书对 Vue.js 3 技术细节的分析非常可靠,对于需要深入理解 Vue.js 3 的用户会有很大的帮助。——尤雨溪,Vue.js作者