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必须赋初始值
	- 暂时性死区
相关推荐
掘金安东尼几秒前
用 CSS 打造完美的饼图
前端·css
掘金安东尼8 小时前
纯 CSS 实现弹性文字效果
前端·css
牛奶8 小时前
Vue 基础理论 & API 使用
前端·vue.js·面试
牛奶8 小时前
Vue 底层原理 & 新特性
前端·vue.js·面试
anOnion9 小时前
构建无障碍组件之Radio group pattern
前端·html·交互设计
pe7er9 小时前
状态提升:前端开发中的状态管理的设计思想
前端·vue.js·react.js
SoaringHeart10 小时前
Flutter调试组件:打印任意组件尺寸位置信息 NRenderBox
前端·flutter
晚风予星10 小时前
Ant Design Token Lens 迎来了全面升级!支持在 .tsx 或 .ts 文件中直接使用 Design Token
前端·react.js·visual studio code
sunny_10 小时前
⚡️ vite-plugin-oxc:从 Babel 到 Oxc,我为 Vite 写了一个高性能编译插件
前端·webpack·架构
GIS之路10 小时前
ArcPy 开发环境搭建
前端