let 和 const 命令
缘由:
就是想学习下ES6,然后就去看了阮一峰的ECMAScript 6 入门,以下的算是一些学习笔记了,其实就是摘抄一些自己觉得是重点的例子,出处都是在阮一峰的ES6入门。
let
ES6 新增了let命令,用来声明变量。它的用法类似于var,但是所声明的变量,只在let命令所在的代码块内有效。
1 | { |
不存在变量提升,let命令改变了语法行为,它所声明的变量一定要在声明后使用,否则报错。
1 | // var 的情况 |
暂时性死区,只要块级作用域内存在let命令,它所声明的变量就“绑定”(binding)这个区域,不再受外部的影响。
1 | var tmp = 123; |
不允许重复声明,let不允许在相同作用域内,重复声明同一个变量。
1 | // 报错 |
const
const声明一个只读的常量。一旦声明,常量的值就不能改变。
1 | const PI = 3.1415; |
const声明的变量不得改变值,这意味着,const一旦声明变量,就必须立即初始化,不能留到以后赋值。
1 | const foo; |
const的作用域与let命令相同:只在声明所在的块级作用域内有效。
1 | if (true) { |
const命令声明的常量也是不提升,同样存在暂时性死区,只能在声明的位置后面使用。
1 | if (true) { |
const声明的常量,也与let一样不可重复声明。
1 | var message = "Hello!"; |