1.es6中使用let声明变量时,为了解决变量提升会有暂时性死区,说明在JavaScript编译时变量就已经存在,但是如果有let声明,则在let声明之前,这个变量不能使用。这与var不一样,var声明之前,变量也存在并且可以使用,只是值为undefined。
2.如果没有块级作用域,所有地方都用var声明,则在函数内重新声明相同变量的话,全局变量将被覆盖。若果存在循环语句,循环语句中的循环控制变量就变成了全局变量,泄露了。
3.所以按照let的特性,let声明就是代表js的块级作用域,let不会影响外部变量,只要在不同的{ }中,就是不同的块级作用域。
4.外层作用域无法读取内层作用域的变量,内层作用域可以定义外层作用域的同名变量。
5.虽然es5不允许在块级作用域中声明函数,但是浏览器还是支持这种声明方式,而且会将块级作用域中声明的函数升级为全局函数。es6明确规定在块级作用域中 声明的函数类似于let 声明的变量。但是为了兼容旧代码,允许浏览器不遵从这一规定。
6.虽然有各种规定但是最好将函数声明语句改为
let f = function () {
return a;
};,这种函数表达式。
7.const与let一样都是块级作用域声明方式,也存在暂时性死区,为了const不可改变值的特性,所以在声明const变量的同时就必须给变量赋值初始化。与let一样,在同一作用域不可重复声明
8.const实际上保证的,并不是变量的值不得改动,而是变量指向的那个内存地址不得改动。而对于复合类型的数据(主要是对象和数组),变量指向的内存地址,保存的只是一个指针,const只能保证这个指针是固定的,至于它指向的数据结构是不是可变的,就完全不能控制了。
es6学习第一章-let与const
最新推荐文章于 2024-04-30 18:36:22 发布