ES6之const关键字

来源:互联网 发布:大数据信息化时代 编辑:程序博客网 时间:2024/06/05 08:34

const 的作用

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


常量的特点

1、不可修改

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

2、只在块级作用域起作用,这点与let关键字一样。

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

3、不存在变量提升,必须先声明后使用,这点也跟let关键字一样。

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

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

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

5、声明后必须要赋值

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

常量是一个对象 传址赋值

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

怎么常量Person好像被修改了,name改成了“李四”,而且还添加了age属性,值为20;怎么没有报错,还正常输出,不是说好了常量不可修改吗。
这个时候,我们先引入一个概念:在赋值过程中,我们可以分为传值赋值和传址赋值。这里我们用到了传址赋值,什么叫传址赋值?

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

用const来声明一个对象类型的常量,就是传址赋值。而不可修改的是对象在内存中的地址,而不是对象本身
所以,这就很好的解释刚刚的这段代码为什么不会报错,而是正常输出了。

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

因为修改的只是Person本身,修改的是name属性和增加一个属性age,而地址没变,也不可变,所以并没有违背常量不可修改的约定。

但是,如果这样写呢,就会报错:

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

总结

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