您的位置:首页 > 其它

ES6笔记-- let和const

2017-09-14 00:00 169 查看
先说说let。let有块级作用域一说,即{}就是一个块级作用域。在{}内使用let声明的变量,{}外无法使用。

{let a = 5}
console.log(a)   // Uncaught ReferenceError: a is not defined

再就是和var的区别在于for循环中,在for循环中时候var声明的变量,i指向同一个,而是用let声明的变量都是独立的。

var a = [];
for (var i = 0; i < 10; i++) {
a[i] = function () {
console.log(i);
};
}
a[6](); // 10  循环内被赋给数组 a 的函数内部的console.log(i),里面的 i 指向的就是全局的 i

var a = [];
for (let i = 0; i < 10; i++) {
a[i] = function () {
console.log(i);
};
}
a[6](); // 6 当前的 i 只在本轮循环有效,所以每一次循环的i其实都是一个新的变量

let命令不存在变量提升存在暂时性死区,所以养成好习惯:变量一定要先声明后使用。

对于函数声明,环境导致的行为差异,避免在块级作用域内声明函数。如果确实需要,也应该写成函数表达式,而不是函数声明语句!!!

对于const的理解,需要注意其 不变 的含义:const实际上保证的,并不是变量的值不得改动,而是变量指向的那个内存地址不得改动。(所以对于非引用数据类型地址保存了该数值,而对于引用数据类型地址是一个指针),因此const声明的对象中的key,value是可以改变的,如果真的想将对象冻结,应该使用Object.freeze方法。

最后,在ES6中声明变量的方式有6中: var、function、let、const、import、class
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  ES语法