三、const常量声明方式

cosnt是es6中常量的声明方式,声明方法和var、let声明方式一样,但是有点不同的是,const声明方式必须立即初始化变量,并且也不能在后面改变他的值

const foo; // SyntaxError: Missing initializer in const declaration
复制代码

下面这个改变值也会报错

const foo = 1;
foo = 2; // TypeError: Assignment to constant variable
复制代码

常量也是块级作用域,以下演示

function func() {
    if (true) {
        const tmp = 123;
    }
    console.log(tmp); // Uncaught ReferenceError: tmp is not defined
}
func();
复制代码

总是说const申明的常量是不可变的,并不意味着是不管怎样都不能改变 其实在js中基本数据类型==Undefined、Null、Boolean、Number 和String==
用const声明方式的值是不能改变的,但是如果的引用类型,如对象,那里面的值是可以改变的

const foo = {};
foo['prop'] = "Moo"; // This works!
console.log(foo);

复制代码

如果想要foo不会被改变,可以使用Object.freeze(obj) 当我们冻结一个对象的值的时候,这个对象我们不能改变,不能添加值和改变属性,例下所示:

const foo = Object.freeze({});
foo.prop = 123;
console.log(foo.prop) // undefined
复制代码

上面这样使用不会报错,但是在严格模式下"use strict",那就不一样了

"use strict";
const foo = Object.freeze({});
foo.prop = 123; // SyntaxError: Cannot add property prop, object is not extensible
复制代码

总结

const的一个重要点是变量是不可变的,而不是变量指向的值。所在在对象中是改变它的属性值的,如果想要它不可变,可以在"use strict"使用Object.freeze(…​)

转载于:https://juejin.im/post/5b40dfebe51d45194e0b7ea9

### 回答1: const常量和#define的区别在于: 1. const常量是在编译时分配内存,而#define是在预处理时进行文本替换,不会分配内存。 2. const常量有类型,可以进行类型检查,而#define没有类型,只是简单的文本替换。 3. const常量可以进行地址取值操作,而#define不可以。 4. const常量可以在多个文件中共享,而#define只能在定义它的文件中使用。 5. const常量可以进行调试,而#define不可以。 因此,建议在定义常量时优先使用const,而不是#define。 ### 回答2: const常量是C++中常用的一种数据类型。定义了const常量之后,它的值不能改变,因此const常量也被称为“只读变量”。 定义const常量的语法格式如下: const 数据类型 常量名 = 常量值; 其中,const表示定义一个常量,数据类型指定了常量的类型,常量名指定了常量的名字,常量值则指定了常量的值。 与const常量类似的是#define宏定义,它们的区别在于前者是编译器处理的常量,后者是预处理器处理的常量。宏定义不会对常量进行类型检查,容易出现错误,在C++中往往使用const常量来代替宏定义。 const常量非常有用,它可以保证程序在运行过程中某些数值不被无意中修改。另外,const常量也可以作为参数传递给函数,这样可以避免函数中修改传入参数的值,增强程序的可读性和健壮性。在类中,const常量也可以用来声明成员变量,表示它的值在对象生命周期内不会改变。 总之,const常量是C++中非常重要的一种数据类型,它可以保证程序的安全性和稳定性,非常适合用于需要保证某些值不被随意修改的场合。 ### 回答3: let变量在JavaScript中的区别是什么? 在JavaScript中,const常量和let变量是两种常用的声明变量的方式。它们与var的不同之处在于它们在声明后具有不同的作用域和可变性。具体区别如下: 1. const常量声明一个常量时,必须立即初始化常量的值,不能再次赋值。而且,const声明常量是块级作用域,在声明的块级别内可见。此外,如果尝试重新分配const常量,将会引发TypeError错误。 2. let变量:初始化后,let声明的变量可以更改其值。与const一样,let变量也是在块级别的作用域中声明的,但是它在作用域中声明的变量可以被更改赋值。 总的来说,const常量和let变量在声明后都可以使用块级作用域,这意味着它们在声明块级别内可见,而不是在函数级别内。但是,const常量以初始化值之后不能进行赋值,同时,let变量可以被重新赋值。选择const还是let变量,需要根据实际需求和定义变量的用途来判断。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值