let 其用法与var差不多,但所申明变量只能在let命令代码块中有效。

{
    var testa = 1;
    let tb = 22;
    console.log(tb); //22
}
console.log(testa); //1
console.log(tb); //tb is undefined

 用法:

1.不存在变量提升:在let申明变量之前使用该变量,该变量是不可用的

2.暂时性死区:只要进入当前作用域,let所申明的变量就绑定在这个作用域,若在申明变量之前使用该变量,是不可用的。

3.不允许重复申明:不允许在同一个作用域内重复申明同一个变量

  ♦因此:不能在函数内部重新申明参数

//报错
function foo(arg) {
    let arg;
}
//不报错
function foo(arg) {
    {
        let arg;
    }
}

const是一个只读常量,一旦申明,常量的值就不能改变。这就意味着,一旦申明,就必须初始化,不能留到以后在赋值。

const命令和let一样存在:不存在变量提升,暂时性死区。

const本质:实际上保证的不是变量的值不得改动,而是指向变量的内存地址不得改动。对于简单类型的数据,值就保存在变量指向的内存地址中,因此等同于变量。但对复合类型的数据(主要针对对象和数组),变量指向的内存地址保存的是一个指针。const只能保证这个指针是固定的,至于指向他的数据结构是不是可变的,这完全不能控制。因此:将一个对象申明为常量就必须非常小心。

 ES6申明变量的6种方法:var,function,let ,const,import,class

 

posted on 2018-01-23 20:20  sandy.simple  阅读(130)  评论(0编辑  收藏  举报