在ts中const和readonly区别?

在TypeScript中,constreadonly是两种不同的属性修饰符,它们各自有特定的用途和语义。

const关键字在TypeScript中用于声明常量,即一个值在初始化后不能再被改变的变量。这意味着一旦你为一个const变量赋值,你就不能再次为它赋一个新的值。这是TypeScript(以及JavaScript)中的基本特性,用于确保某些值在程序的整个生命周期中保持不变。

例如:

 

typescript复制代码

const PI = 3.14159;
// PI = 3.14; // 这会报错,因为PI是一个常量

readonly是TypeScript中的一个类型级别的修饰符,它用于对象的属性上,表示这个属性是只读的,即它的值在对象被创建后不能被改变。但是,这并不意味着包含只读属性的对象本身不能被重新赋值。这与const不同,const`是变量级别的修饰符,它确保变量的引用不能被改变。

例如:

 

typescript复制代码

interface Person {
readonly name: string;
age: number;
}
let person: Person = {
name: "Alice",
age: 25
};
// person.name = "Bob"; // 这会报错,因为name是只读的
person.age = 26; // 这是可以的,因为age不是只读的
person = { // 这是可以的,因为person变量本身不是const
name: "Bob",
age: 30
};

在这个例子中,Person接口有一个只读属性name和一个非只读属性age。我们创建了一个Person类型的变量person,并尝试改变其name属性,但TypeScript编译器会报错,因为name是只读的。然而,我们可以改变age属性的值,也可以重新为person变量赋值一个新的Person对象。

总的来说,constreadonly在TypeScript中各有其用,它们的主要区别在于const用于确保变量的引用不变,而readonly用于确保对象的特定属性不变。

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值