ES6系列一 let const

Posted SunShineKG

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ES6系列一 let const相关的知识,希望对你有一定的参考价值。

一丶let

1.使用let声明一个变量,会生成一个独立的作用域,比var的作用域更为严谨,比如for循环

var a = [];
for (var i = 0; i < 10; i++) {
  a[i] = function () {
    console.log(i);
  };
}
a[6](); // 10
var a = [];
for (let i = 0; i < 10; i++) {
  a[i] = function () {
    console.log(i);
  };
}
a[6](); // 6

 

2.暂时性死区:在代码块内,使用let命令声明变量之前,该变量都是不可用的。这在语法上,称为“暂时性死区”(temporal dead zone,简称 TDZ)。

3.不能重复性声明: 同一作用域下,var重复声明不会报错,let和const重复声明会报错。

二丶const

1.const声明一个只读变量,不可更改值,否则则会报错,但对象和数组可以更改内存指针。比如

const foo = {};

// 为 foo 添加一个属性,可以成功
foo.prop = 123;
foo.prop // 123


const a = [];
a.push(‘Hello‘); // 可执行
a.length = 0;    // 可执行
a = [‘Dave‘];    // 报错

以上是关于ES6系列一 let const的主要内容,如果未能解决你的问题,请参考以下文章

ES6系列,1.新增let和const命令

JavaScript ES6 的let和const

ES6系列之变量声明let const

[js高手之路] es6系列教程 - var, let, const详解

Es6系列--const

JavaScript系列文章:谈谈let和const