es6 变量声明方式

来源:互联网 发布:chipseq数据分析 编辑:程序博客网 时间:2024/06/05 20:45

## let

  • 基本用法: let是用来生命变量。用法类似于var,但是let命令只在所处的代码块有效。

    {    var a = 10;    let b = 20;}console.log(a) //10console.log(b) //referenceError: a is not defined.
    • 可以避免产生闭包:比如for循环。

      //var 声明的i在全局范围内都有效,每次循环都会覆盖旧值。产生闭包。    for (var i = 0; i < 10; i ++) {    a[i] = function () {        console.log(i);    }}a[6]() ; // 10//let 声明的i只在本轮循环有效,所以每一次循环的i都是一个新的变量。for (let i = 0; i < 10; i ++) {    a[i] = function () {        console.log(i);    }}a[6](); //6
    • 不存在变量声明提升。

      console.log(foo); //2console.log(bar); //refferenceError 报错var foo = 2;let bar = 2;
    • 暂时性死区。

      var tmp = 123;if (true) {    tmp = 'abc'; //referenceError    let tmp;}

      上面代码中,存在全局变量tmp,但是块级作用域内let又声明了一个全局变量tmP,导致后者绑定这个块级作用域,所以在let变量声明之前,对tmp的赋值会报错。

      ES6中明确规定,如果区块中存在let和const命令,这个区块对这些命令声明的变量,从一开始就形成了封闭作用域,凡是在声明之前就使用这些变量就会报错。

      使用typeof也是同理。在出现let等方式之前,typeof百分百不会报错,但是这种情况下,并不安全。与赋值同样会报错。

es6一共有6种声明变量的方法:

    var 、function 、let 、const 、import、 class。