ES6中let,const和 var

let与var

1、let声明的变量是块级作用域(只在所声明的代码块内有效)。在ES6之前,js只存在函数作用域以及全局作用域。

if(1){
    let a=1;
    console.log(a)//1
  }
  console.log(a)//ReferenceError: a is not defined

2、let不存在变量提升(必须遵循“先声明,后使用”的原则)

console.log(a); //ReferenceError: b is not defined
 let a=2;

3、let在同一作用域内不能重复定义

 let a=5;
 let a=5;
console.log(a);//Uncaught SyntaxError: Identifier 'a' has already been declared

4、暂时性死区:在代码块内,使用let声明变量之前,该变量都是不可以使用的

let a =1;
  function fn(){
    console.log(a);
    let a = 2;
  }

  fn();//Uncaught ReferenceError: Cannot access 'a' before initialization

ES6规定,如果在区块中存在let和const声明的变量,则这个区块对这些声明的变量从一开始就形成一个封闭的作用域。不管在外部有没有声明这个变量。必须遵守“先声明,后使用”的原则,否则报错

暂时性死区的本质就是,只要一进入当前作用域,所使用的变量就已存在,但是不可获取,只有等到声明变量的哪一行代码的出现,在可以获取和使用该变量

暂时性死区的意义:让我们标准化代码。将所有的变量的声明放在作用域的最开始,主要是为了减少运行程序的错误,防止出现“先使用(变量),后声明(变量)”的情况

const命令的基本使用

1、只在块级作用域内有效
2、必须先声明,后使用
3、在同一作用域,const不能重复声明同一常量
4、const声明的常量不能改变(不能先声明,后初始化)

const b = 1;
  b = 2;

  console.log(a);//Uncaught TypeError: Assignment to constant variable.

猜你喜欢

转载自blog.csdn.net/weixin_45629194/article/details/102495893