ECMAScript6中let命令和const命令

1. let命令

ES6新增let命令,用来声明变量。它的用法类似var,但是所声明的变量只在let命令所在的代码块内有效。

1. let 和 var 区别

  1. let是块级作用域(存在块级嵌套问题),var是函数作用域;
  2. let声明的变量不存在变量声明提升(需要先声明后使用),var有声明提升;
  3. let声明的变量存在暂时性死区(TDZ),暂时性死区主要说的是(先声明后使用的问题);
  4. 不允许重复声明(不允许在同一作用域内,重复声明同一个变量);

2. 不存在变量提升

console.log(a);//报错
let a = "helloworld"

3. 暂时性死区

只要块级作用域内存在let命令,它所声明的变量就绑定这个区域,不在受外部的影响

var a = 11;
{
	let a = 10;
	{
		console.log(a);//报错,a不满足先声明后使用的原则,在外层作用域虽然声明了变量a,但是在当前作用域也声明了同名变量a,这就存在暂时性死区问题,当前a会绑定锁死当前块级作用域
		let a = 5;
	}
}

2. const命令

声明一个只读的常量。一旦声明,常量的值就不能更改

注意

  1. const声明的常量,生命的时候必须赋值;
  2. const声明的常量,后去不恶意再赋值修改;
  3. const声明的常量,一般都是全部大写;
const a = 10;
a = 1; //报错,const声明的常量不可修改
const a;//报错,声明的时候没有赋值

发布了54 篇原创文章 · 获赞 7 · 访问量 2073

猜你喜欢

转载自blog.csdn.net/baobao__/article/details/102406710