ES6-const

一、基本用法

复制代码
- 语法:
	const 标识符=初始值;
	注意:const一旦声明变量,就必须立即初始化,不能留到以后赋值
- 规则:
	1.const 声明一个只读的常量,一旦声明,常量的值就不能改变
	2.const 其实保证的不是变量的值不变,
	  而是保证变量指向的内存地址所保存的数据不允许改动
  • 重点
java 复制代码
		不可变值(相当于常量):简单类型的数据(数值、字符串、布尔值)
		数据结构可变:  复合类型的数据(主要是对象和数组)

二、本质

java 复制代码
- const实际上保证的,并不是变量的值不得改动,
  而是变量指向的那个内存地址所保存的数据不得改动。
	1.对于简单类型的数据(数值、字符串、布尔值),
	  值就保存在变量指向的那个内存地址,因此等同于常量。
	2.对于复合类型的数据(主要是对象和数组),
	  变量指向的内存地址,保存的只是一个指向实际数据的指针,
	  const只能保证这个指针是固定的(即总是指向另一个固定的地址),
	  至于它指向的数据结构可变化。

三、示例

1)数组

js 复制代码
const arr=[]
console.log(arr) // []
arr.push('wyt')
console.log(arr) //['wyt']

2)对象

javascript 复制代码
//添加name属性
  const obj = {}
  obj.name = "wyt"
  console.log(obj);
  • 冻结对象

    js 复制代码
    const foo = Object.freeze({});
    // 常规模式时,下面一行不起作用;
    // 严格模式时,该行会报错
    foo.prop = 123;

四、规则

java 复制代码
- 同let一样(若忘记,可以看ES6-let那篇文章)
	- 同一个作用域内不允许重复声明
	- 不存在变量提升即必须先声明再使用,但是const必须赋初始值
	- 暂时性死区
相关推荐
10年前端老司机1 小时前
React无限级菜单:一个项目带你突破技术瓶颈
前端·javascript·react.js
阿芯爱编程6 小时前
2025前端面试题
前端·面试
前端小趴菜057 小时前
React - createPortal
前端·vue.js·react.js
晓13137 小时前
JavaScript加强篇——第四章 日期对象与DOM节点(基础)
开发语言·前端·javascript
菜包eo7 小时前
如何设置直播间的观看门槛,让直播间安全有效地运行?
前端·安全·音视频
烛阴8 小时前
JavaScript函数参数完全指南:从基础到高级技巧,一网打尽!
前端·javascript
chao_7899 小时前
frame 与新窗口切换操作【selenium 】
前端·javascript·css·selenium·测试工具·自动化·html
天蓝色的鱼鱼9 小时前
从零实现浏览器摄像头控制与视频录制:基于原生 JavaScript 的完整指南
前端·javascript
三原9 小时前
7000块帮朋友做了2个小程序加一个后台管理系统,值不值?
前端·vue.js·微信小程序
popoxf10 小时前
在新版本的微信开发者工具中使用npm包
前端·npm·node.js