ES6 const命令

const命令与let命令相似,只不过let声明变量,const声明常量

我们const声明一个只读常量。一旦声明,常量的值就不能改变;

常规写法:

const PI=3.333;
console.log(PI);

const指令报错情况:

       //第一种:const声明完常量,不可改变,一旦改变常量值会报错
        const PI=3.333;
        PI=3;
        console.log(PI);//报错;Uncaught TypeError: Assignment to constant variable.
        
     

          const fun={};
      fun={};
      console.log(fun);//报错;Assignment to constant variable

      const a = [];
      a = [];
      console.log(a);

        //第二种:const一旦声明,就必须立即初始化,不能留到以后赋值。
       
     const a; console.log(a);//报错;Missing initializer in const declaration //第三种:const所在的代码块为块级作用域,所以其变量只在块级作用域内使用或其中的闭包使用。
     if(true){ const M=4; } console.log(M);//报错; M is not defined //第四种:const声明的变量不存在变量提升    if(true){   console.log(a);//报错;Cannot access 'a' before initialization    const a=10;      }    //第五种:不可重复声明变量
   var message = "Hello!";    let age = 25; const message = "Goodbye!"; const age = 30; console.log(message);//报错;Identifier 'message' has already been declared console.log(age);//报错;Identifier 'age' has already been declared

本质:

按阮一峰老师所讲,const实际上保证的,并不是变量的值不得改动,而是变量指向的那个内存地址所保存的数据不得改动。对于简单类型的数据(数值、字符串、布尔值),值就保存在变量指向的那个内存地址,因此等同于常量。但对于复合类型的数据(主要是对象和数组),变量指向的内存地址,保存的只是一个指向实际数据的指针,const只能保证这个指针是固定的(即总是指向另一个固定的地址),至于它指向的数据结构是不是可变的,就完全不能控制了。因此,将一个对象声明为常量必须非常小心。

const在以下几种情况不会报错

const person={};//声明对象
person.name='wzx';//添加对象属性
person.age=24;
console.log(person.name);//

const number=[];//声明数组
number.push(4,5);//添加数组
console.log(number);

输出结果:

如果希望将对象本身冻结,可以使用Object.freeze()方法。

const person=Object.freeze({});
    person.name="wzx";
    console.log(person.name); //undefined

猜你喜欢

转载自www.cnblogs.com/smile-xin/p/11401807.html
今日推荐