首页 > 代码库 > ECMAScript 6 入门学习笔记(一)——let和const
ECMAScript 6 入门学习笔记(一)——let和const
一、let
①声明变量 let a = 1;
②只在所在代码块内有效,不影响块以外
③不存在变量提升(不能先用后声明)
④暂时性死区
let声明的变量“绑定”这个区域,不受外部影响。
let声明之前,都是这个变量的‘死区’
注:typeof在死区是ReferenceError,没声明是“undefined”
⑤不能重复声明同一个变量
二、块级作用域
① 允许块级作用域的任意嵌套,外层作用域无法读取内层作用域的变量,内层作用域可以定义外层作用域的同名变量
// IIFE 写法 (function () { var tmp = ...; ... }()); // 块级作用域写法 { let tmp = ...; ... }
②允许在块级作用域之中声明函数(不建议使用,浏览器环境不同,差异大)
③do表达式(得到块级作用域的返回值)
let x = do { let t = f(); t * t + 1; };
三、const
①声明一个只读的常量。一旦声明,常量的值就不能改变。
②不能只声明不赋值
③只在声明所在的块级作用域内有效
④存在暂时性死区,只能在声明的位置后面使用
⑤不可重复声明
⑥本质:const实际上是保证变量指向的内存地址不得改动,不是变量值不能改(对象和数组)
⑦es6六种声明变量方法:var,function,let,const,import,class
四、顶层对象的属性
①顶层对象:浏览器 --> window对象 Node --> global对象
②var命令和function命令声明的全局变量,属于顶层对象的属性;
let命令、const命令、class命令声明的全局变量,不属于顶层对象的属性
五、global对象
①顶层对象不一定总能取到,system.global让global作为顶层对象,让它在各种环境下都存在。
ECMAScript 6 入门学习笔记(一)——let和const