TypeScript 是一种由微软开发的自由和开源的编程语言,它是 JavaScript 的一个超集,扩展了 JavaScript 的语法,TypeScript 可以编译成纯 JavaScript,可以在任何浏览器、任何计算机和任何操作系统上运行,在 TypeScript 中,Record 类型是一种特殊的类型,它允许你创建具有特定属性名和类型的对象。
创新互联公司始终坚持【策划先行,效果至上】的经营理念,通过多达10余年累计超上千家客户的网站建设总结了一套系统有效的全网营销解决方案,现已广泛运用于各行各业的客户,其中包括:工商代办等企业,备受客户表扬。
Record 类型简介
Record 类型是 TypeScript 4.2 版本引入的一个新特性,它允许你使用一组已知的属性名和它们的类型来创建一个新的对象类型,Record 类型可以让你更简洁地表示具有固定属性的对象,而不需要显式地定义每个属性的类型。
假设我们有一个具有两个属性 name
和 age
的对象:
interface Person { name: string; age: number; } const person: Person = { name: '张三', age: 30, };
使用 Record 类型,我们可以简化这个对象的定义:
type Person = Record<'name' | 'age', string | number>; const person: Person = { name: '张三', age: 30, };
Record 类型的基本用法
Record 类型的基本用法是将一组属性名和它们的类型用 Record
关键字包裹起来,属性名可以是字符串字面量或符号,类型可以是任何类型,如果属性名是一个字符串字面量,那么它的值必须是字符串;如果属性名是一个符号,那么它的值必须是该符号对应的类型。
我们可以创建一个表示颜色的 Record 类型:
type Color = Record<'red' | 'green' | 'blue', string>; const color: Color = { red: '#FF0000', green: '#008000', blue: '#0000FF', };
在这个例子中,我们创建了一个名为 Color
的 Record 类型,它有三个属性:red
、green
和 blue
,它们的类型都是字符串,然后我们创建了一个 color
对象,它具有这三个属性,并分别赋值为红色、绿色和蓝色的十六进制颜色代码。
Record 类型的高级用法
可选属性
你可以使用问号(?
)来表示一个可选的属性,这意味着该属性的值可以为 undefined
。
type PersonOptional = Record<'name' | 'age' | 'gender'?, string | number | undefined>; const personOptional: PersonOptional = { name: '张三', age: 30, };
在这个例子中,我们创建了一个名为 PersonOptional
的 Record 类型,它有三个属性:name
、age
和可选的 gender
,然后我们创建了一个 personOptional
对象,它具有 name
和 age
属性,但没有 gender
属性,注意,这里的 gender
属性值为 undefined
。
只读属性
你可以使用 readonly
关键字来表示一个只读的属性,这意味着该属性的值只能在对象初始化时设置,之后不能被修改。
type PersonReadonly = Record<'name' | 'age' | 'gender' | 'isStudent' | 'isEmployee' | 'isTeacher', string | number | boolean>; const personReadonly: PersonReadonly = { name: '张三', age: 30, gender: '男', isStudent: true, isEmployee: false, isTeacher: false, };
在这个例子中,我们创建了一个名为 PersonReadonly
的 Record 类型,它有七个属性:name
、age
、gender
、isStudent
、isEmployee
、isTeacher
,然后我们创建了一个 personReadonly
对象,它具有这些属性,并在初始化时设置了它们的值,由于没有使用 readonly
关键字,所以这些属性的值之后仍然可以被修改,如果你尝试修改这些属性的值,TypeScript 编译器会报错,要创建一个真正的只读对象,你需要使用 TypeScript 的 Readonly
类型:
const personReadonly: Readonly= { ...personReadonly, isStudent: false }; // Error! Property 'isStudent' is readonly.
在这个例子中,我们使用了 Readonly
类型来创建一个真正的只读对象,当我们尝试修改 isStudent
属性的值时,TypeScript 编译器会报错,提示该属性是只读的。
本文题目:TypeScriptRecord类型详解
网站路径:http://www.mswzjz.cn/qtweb/news21/230871.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能