• ES6 let 和 const


    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

  • 相关阅读:
    Java入门
    Java入门
    Java入门
    Java入门
    Java入门
    Java入门
    Java入门
    Java入门
    leyou_04_vue.js的ajax请求方式
    leyou_03_cors解决ajax的跨域请求问题
  • 原文地址:https://www.cnblogs.com/wangwenhui/p/8324460.html
Copyright © 2020-2023  润新知