TypeScript中的实用工具类型(Utility Types)|全球今热点
TypeScript中的实用工具类型是一些预定义的泛型类型,可用于操作或创建其它新类型。这些实用工具类型在所有TypeScript项目中都是全局可用的,因此无需添加任务依赖项即可使用它们。
1.Partial
将Type的所有属性都设置为可选的类型。
【资料图】
1 interface Person { 2 name: string; 3 age: number; 4 email: string; 5 } 6 7 type PartialPerson = Partial; 8 9 //相当于10 // interface Person {11 // name?: string | undefined;12 // age?: number | undefined;13 // email?: string | undefined;14 // }15 16 interface Todo {17 title: string;18 description: string;19 }20 21 function updateTodo(todo: Todo, fieldsToUpdate: Partial ) {22 return { ...todo, ...fieldsToUpdate };23 }24 25 const todo1 = {26 title: "organize desk",27 description: "clear clutter",28 };29 30 const todo2 = updateTodo(todo1, {31 description: "throw out trash",32 });
2.Required
与Partical
1 interface Person { 2 name?: string | undefined; 3 age?: number | undefined; 4 email?: string | undefined; 5 } 6 7 8 type RequiredPerson = Required; 9 10 // 相当于11 // interface Person {12 // name: string;13 // age: number;14 // email: string;15 // }
3.Omit
构建一个新类型--从类型Type
中获取所有属性,然后从中剔除Keys
属性。
1 interface User { 2 id: number; 3 name: string; 4 email: string; 5 age: number; 6 } 7 8 type UserWithoutEmail = Omit; 9 10 // 相当于11 // interface Person {12 // id: string;13 // name: string;14 // age: number;15 // }
也可以移除多个属性,
1 interface User { 2 id: number; 3 name: string; 4 email: string; 5 age: number; 6 } 7 8 type UserWithoutEmailAndName = Omit; 9 10 // 相当于 11 // interface Person {12 // id: string;13 // age: number;14 // }
4.Pick
从类型Type
中挑选部分属性Keys
来构造类型,与Omit相反。
1 interface User { 2 id: number; 3 name: string; 4 email: string; 5 age: number; 6 } 7 8 type UserWithEmailAndName = Pick; 9 10 // 相当于11 // interface Person {12 // name: string;13 // email: string;14 // }
可以组合使用这些类型,创造新的类型
1 interface User { 2 id: number; 3 name: string; 4 email: string; 5 age: number; 6 } 7 8 type PartialPick = Partial>; 9 10 // 相当于11 // interface Person {12 // name?: string | undefined;13 // email?: string | undefined;14 // }
1 interface User { 2 id: number; 3 name: string; 4 email: string; 5 age: number; 6 } 7 8 type OmitPartialPick = Omit>, "email">; 9 10 // 相当于 11 // interface Person {12 // name?: string | undefined;13 // }
5.Readonly
通过该Type构造新类型,并将它所有的属性设置为只读的,也就意味着构造出的类型的属性不能被再次赋值。
1 interface Person { 2 id: number; 3 name: string; 4 age: number; 5 } 6 7 type ReadonlyPerson = Readonly; 8 9 //相当于10 // interface Person {11 // readonly id: number;12 // readonly name: string;13 // readonly age: number;14 // }15 16 const person: ReadonlyPerson = {17 id: 1,18 name: "John",19 age: 2520 };21 22 person.name = "Mike"; // Error: Cannot assign to "name" because it is a read-only property.
这个类型可用来表示在运行时会失败的赋值表达式(比如,当尝试给冻结对象的属性再次赋值时)
Object.freeze
1 function freeze(obj: T): Readonly ;
6.Record
构造一个对象类型,其属性为Keys,属性值为Type;该实用工具类型可用于将一种类型的属性映射到另一种类型。
1 interface CatInfo { 2 age: number; 3 breed: string; 4 } 5 6 type CatName = "miffy" | "boris" | "mordred"; 7 8 const cats: Record= { 9 miffy: { age: 10, breed: "Persian" },10 boris: { age: 5, breed: "Maine Coon" },11 mordred: { age: 16, breed: "British Shorthair" },12 };13 14 cats.boris;15
7.Exclude
通过从 UnionType 中排除所有可分配给 ExcludedMembers 的属性来构造一个类型;也就是删除 union 类型的成员来创建新类型。
1 type T0 = Exclude<"a" | "b" | "c", "a">;2 type T0 = "b" | "c"3 4 type T1 = Exclude<"a" | "b" | "c", "a" | "b">;5 type T1 = "c"6 7 type T2 = Excludevoid), Function>;8 type T2 = string | number
8.Extract
通过从 Type 中提取可分配给 Union 的所有联合成员来构造一个类型,与 Exclude 相反。
1 type T0 = Extract<"a" | "b" | "c", "a" | "f">;2 type T0 = "a"3 4 type T1 = Extractvoid), Function>;5 type T1 = () => void
9.NonNullable
通过从 Type 中排除 null 和 undefined 来构造一个类型。
1 type T0 = NonNullable;2 type T0 = string | number3 4 type T1 = NonNullable ;5 type T1 = string[]
10.ReturnType
由函数类型Type
的返回值类型构建一个新类型。
1 function add(a: number, b: number): number { 2 return a + b; 3 } 4 5 type AddReturnType = ReturnType; 6 // type AddReturnType = number; 7 8 9 function addStr(a: string, b: string): string{10 return a + b;11 }12 13 type AddReturnType2 = ReturnType ;14 // type AddReturnType2 = string;15 16 type T0 = ReturnType<() => string>;17 type T0 = string18 19 type T1 = ReturnType<(s: string) => void>;20 type T1 = void21 22 type T2 = ReturnType< () => T>; 23 type T2 = unknown24 25 type T3 = ReturnType< () => T>;26 type T3 = number[]
11.Parameters
由函数类型Type
的参数类型来构建出一个元组类型。
1 function add(a: number, b: string, c:boolean): string { 2 return a + b; 3 } 4 5 type AddReturnType = Parameters; 6 // type AddReturnType = [a: number, b: string, c:boolean]; 7 8 type T0 = Parameters<() => string>; 9 type T0 = []10 11 type T1 = Parameters<(s: string) => void>;12 type T1 = [s: string]13 14 type T2 = Parameters< (arg: T) => T>;15 type T2 = [arg: unknown]
12.Awaited
这种类型旨在模拟异步函数中的 await 或 Promises 上的 .then() 方法等操作——具体来说,就是它们递归展开 Promises 的方式。
1 async function fetchData(): Promise{ 2 // fetch data from API and return a string 3 } 4 5 type ResolvedResult = Awaited >; 6 // type ResolvedResult = string 7 8 type A = Awaited >; 9 type A = string10 11 type B = Awaited >>; 12 type B = number13 14 type C = Awaited >; 15 type C = number | boolean
以上,是较常用的一些实用工具类型。
参考资料:
https://www.typescriptlang.org/docs/handbook/utility-types.html#uppercasestringtype
https://dev.to/arafat4693/typescript-utility-types-that-you-must-know-4m6k
关键词:
-
TypeScript中的实用工具类型(Utility Types)|全球今热点
2023-04-23 -
峨眉人 时刻绷紧“防火”弦
2023-04-23 -
msdownld tmp 世界时讯
2023-04-22 -
肉丸蒸多久就可以熟了呢 肉丸蒸多久才熟 每日热闻
2023-04-22 -
华自科技(300490):国泰君安证券股份有限公司关于公司2023年度日常关联交易预计的核查意见
2023-04-22 -
通讯!武汉汉阳:我家有个读书“廊”
2023-04-22 -
环球关注:鄂州市气象局发布暴雨橙色预警【II级/严重】【2023-04-22】
2023-04-22 -
印度38个城市气温超40℃,极端高温或致印度GDP损失2.8%|天天新视野
2023-04-22 -
如何抄股(财富庄园橘子委托出售)_消息
2023-04-22 -
瞰中国|内蒙古兴安盟:春风沐突泉 杏花朵朵开
2023-04-22 -
闭音节是什么_闭音节 全球快资讯
2023-04-22 -
长沙金沙里社区:宜居靓家园,健康新生活
2023-04-22 -
世界观速讯丨审计项目分类管理办法_审计项目分类
2023-04-22 -
蓝海智能AI大通拓客软件互联网短视频涨粉引流推广风口创业项目-当前信息
2023-04-22 -
天天快资讯:无根生是谁图片_无根生是谁
2023-04-22 -
刚刚,央行重磅发声!
2023-04-22 -
清宫打的是什么麻药_清宫麻药打在什么部位|快播报
2023-04-22 -
偷钱的金额一般多少金额算犯罪 动态焦点
2023-04-22 -
刺黄连的功效与作用_刺黄连有什么功效与作用
2023-04-22 -
海绵铁滤料商品报价动态(2023-04-22)
2023-04-22 -
名嘴狂喷小卡:宁要欧文都不要他 他现在就应该退役 天天观察
2023-04-22 -
曝三星Galaxy Z Flip 5手机前摄不变,仍为1000万像素
2023-04-22 -
预警!猪价“涨不动”,豆粕行情“跳水”,羊价惨淡,发生了啥?
2023-04-22 -
图知道|保护地球,青年接力
2023-04-22 -
hero首发官宣,久哲心碎了:紫幻后又来个誓约,又出师未捷阵先崩
2023-04-22 -
车展E快评 | 补足驾驶辅助短板 AITO问界M5智驾版静态体验
2023-04-22 -
围绕中心意思写的作文500字左右_围绕中心意思写的作文
2023-04-22 -
天天滚动:润和软件协办openEuler开发者峰会2023,发布联合创新成果
2023-04-22 -
剑阁县气象台更新大风蓝色预警信号【IV级/一般】【2023-04-22】
2023-04-22 -
每日资讯:黄泥岗上施巧施功干的一件大事是_黄泥冈上巧施功干的一件大事是
2023-04-22
-
守住网络直播的伦理底线
2021-12-16 -
石窟寺文化需要基于保护的“新开发”
2021-12-16 -
电影工作者不能远离生活
2021-12-16 -
提升隧道安全管控能力 智慧高速让司乘安心
2021-12-16 -
人民财评:提升消费体验,服务同样重要
2021-12-16 -
卫冕?突破?旗手?——武大靖留给北京冬奥会三大悬念
2021-12-16 -
新能源车险专属条款出台“三电”系统、起火燃烧等都可保
2021-12-16 -
美术作品中的党史 | 第97集《窗外》
2021-12-16 -
基金销售业务违规!浦发银行厦门分行等被厦门证监局责令改正
2021-12-16 -
保持稳定发展有支撑——从11月“成绩单”看中国经济走势
2021-12-16