【ES6标准入门】JavaScript中的const的使用和本质(一些使用细节)

在这里插入图片描述

😁 作者简介:一名大三的学生,致力学习前端开发技术
⭐️个人主页:夜宵饽饽的主页
❔ 系列专栏:前端js专栏
👐学习格言:成功不是终点,失败也并非末日,最重要的是继续前进的勇气

​🔥​前言:

这是自己在学习JavaScript的学习笔记和总结,希望可以帮助到你

2.3 const 命令

2.3.1 基本用法
  1. const 声明一个只读常量。一旦声明,常量的值就不能改变

    const PI=3.1415;
    console.log(PI) //3.1415
    
    PI=3;
    //TypeError:Assignment to constant variable
    

    上面的代码表明改变常量的值会报错

  2. const 声明的常量不得改变值,这意味着,const 一旦声明常量,就必须立即初始化,不能留到以后赋值

    const a
    //SyntaxError:Missing initializer in const declaration
    

    上面的代码表示,对于const 而言 只声明不赋值就会报错。

  3. const 的作用域与let 命令相同:只在声明所在的块级作用域内有效

    if(true){
    const MAX=5
    }
    MAX//Uncaught ReferenceError:MAX is not defined
    
  4. const 命令声明的常量也不会提升,同样存在暂时性死区,只能在声明后使用

    if(true){
    	console.log(MAX) //ReferenceError
        const MAX=5
    }
    
  5. 使用const声明的变量也与let 一样,不可重复声明

2.3.2 本质

​ const 实际上保证并不是变量的值不得改动,而是变量指向得那个内存地址不得改动,对于简单类型的数据(数值,字符串,布尔值)而言,值就保存在变量指向的内存地址中,而复合类型(数组和对象)而言,变量指向的内存地址保存的只是一个指针,const只能保证这个指针是固定的。

const fpp={}

//为foo添加一个属性,可以成功
foo.prop=123
foo.prop //123

//将foo指向另一个对象,就会报错
foo={}//TypeError:'foo' is read-only

上述的代码中,常量foo储存的是一个地址,这个地址指向一个对象,不可变的只是这个地址,即不能把foo指向另一个地址,但对象本身是可变的,所以依然可以为其添加新属性

数组也是一样的

const a=[]
a.push('b');//可以执行
a.length=0;//可以执行
a=['c']//报错

上面的代码中,常量a是一个数组,这个数组本身是可写的,但是如果将另一个数组赋值给a就会报错

如果我们真的想把对象冻结,应该使用Object.freeze方法

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值