es6 const关键字

 const是constant(常量)的缩写,const和 let同样,也是用来声明变量的,可是const是专门用于声明一个常量的,顾名思义,常量的值是不可改变的。之前用var声明的变量,想怎么改就怎么改,同一个变量,后面的值能够轻松覆盖原来的值,此次const声明的变量,可由不得咱们这么任性地想改就改了。spa

1.不可修改code

const Name = '张三';
Name = '李四';//错误,企图修改常量Name

2.只在块级做用域起做用,这点与let关键字同样。对象

    if(1){
       const Name = '张三';
     }
    alert(Name);//错误,在代码块{ }外,Name失效

3.不存在变量提高,必须先声明后使用,这点也跟let关键字同样。blog

    if(1){
        alert(Name);//错误,使用前未声明
        const Name = '张三';
    }

4.不可重复声明同一个变量,这点跟let也同样。作用域

    var Name  = '张三';
    const  Name = '李四';//错误,声明一个已经存在的变量Name

5.声明后必需要赋值console

const NAME; //错误,只声明不赋值

若是常量是一个对象呢?来看下面的代码class

    const Person = {"name":"张三"};
    Person.name = "李四";
    Person.age = 20;
    console.log(Person);
    //结果:正常输出{name: "李四", age: 20}

怎么常量Person好像被修改了,name改为了“李四”,并且还添加了age属性,值为20;怎么没有报错,还正常输出?变量

这主要是由于传址赋值引用

在赋值过程当中,咱们能够分为传值赋值和传址赋值。这里咱们用到了传址赋值,什么叫传址赋值?总结

传址:在赋值过程当中,变量实际上存储的是数据的地址(对数据的引用),而不是原始数据或者数据的拷贝。

    var student1 = {"name":"张三"};
    var student2 = student1;
    student2.name = "李四";
    console.log(student1);
    //结果:输出 {name: "李四"}
    console.log(student2);
    //结果:输出 {name: "李四"}

可是,若是这样写呢,就会报错:

    const Person = {"name":"张三"};
    Person.age = 20;
    Person = {}; 
    //错误,企图给常量Person赋新值(新地址)

总结:const也是用于声明一个常量,并必须赋值,声明后不可修改,跟let同样,只在块级做用域起做用,不可重复声明同一个变量,不会变量提高,声明引用类型的常量时,要注意是传址赋值。

相关文章
相关标签/搜索