zoukankan      html  css  js  c++  java
  • 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
  • 相关阅读:
    AC自动机模板
    输入输出外挂(整数)
    前同事通过接私活年入60W,他常用19个私活平台汇总!
    通用分页存储过程
    单品流向
    口令对照表
    连接字符串大全
    各搜索引擎登记入口
    moto手机软件收集
    resin在线客户系统
  • 原文地址:https://www.cnblogs.com/smile-xin/p/11401807.html
Copyright © 2011-2022 走看看