成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

15 種TypeScript最常用的實用程序類型

開發(fā) 前端
我們在使用 TypeScript 的過程中,我們是面向類型編程的,為了滿足不同的工作場景,我們需要對已知類型進(jìn)行改造。

為了方便 TypeScript 用戶,TypeScript 開發(fā)團(tuán)隊為我們提供了許多有用的內(nèi)置實用程序類型。通過這些實用類型,我們

可以輕松地轉(zhuǎn)換類型、提取類型、排除類型,或者獲取函數(shù)的參數(shù)類型或返回值類型。

在本文中,我從 TypeScript 的內(nèi)置實用程序類型中挑選了 15 種非常有用的類型,并以圖像的形式介紹了它們的用法和內(nèi)部工作原理,看完這篇文章,相信你可以真正掌握這些內(nèi)置實用程序類型的用法。

1.Partial<Type>

構(gòu)造一個類型,其中 Type 的所有屬性都設(shè)置為可選。

/** * Make all properties in T optional.  * typescript/lib/lib.es5.d.ts */type Partial<T> = {    [P in keyof T]?: T[P];};

2.  Required<Type>

構(gòu)造一個類型,該類型由設(shè)置為 required  Type 的所有屬性組成,部分的反義詞。

圖片

/** * Make all properties in T required. * typescript/lib/lib.es5.d.ts */type Required<T> = {    [P in keyof T]-?: T[P];};

圖片

3.Readonly<Type>

構(gòu)造一個 Type 的所有屬性都設(shè)置為 readonly 的類型,這意味著構(gòu)造類型的屬性不能被重新分配。

圖片

/** * Make all properties in T readonly. * typescript/lib/lib.es5.d.ts */type Readonly<T> = {    readonly [P in keyof T]: T[P];};

4.Record<Keys, Type>

構(gòu)造一個對象類型,其屬性鍵為 Keys,其屬性值為 Type,此實用程序可用于將一種類型的屬性映射到另一種類型。

/** * Construct a type with a set of properties K of type T. * typescript/lib/lib.es5.d.ts */type Record<K extends keyof any, T> = {    [P in K]: T;};

5. Exclude<UnionType, ExcludedMembers>

通過從 UnionType 中排除可分配給 ExcludedMembers 的所有聯(lián)合成員來構(gòu)造類型。

圖片

/** * Exclude from T those types that are assignable to U. * typescript/lib/lib.es5.d.ts */type Exclude<T, U> = T extends U ? never : T;

圖片

6. Extract<Type, Union>

通過從 Type 中提取所有可分配給 Union 的聯(lián)合成員來構(gòu)造一個類型。

/** * Extract from T those types that are assignable to U. * typescript/lib/lib.es5.d.ts */type Extract<T, U> = T extends U ? T : never;

7. Pick<Type, Keys>

通過從 Type 中選擇一組屬性 Keys(字符串文字或字符串文字的聯(lián)合)來構(gòu)造一個類型。

圖片

/** * From T, pick a set of properties whose keys are in the union K. * typescript/lib/lib.es5.d.ts */type Pick<T, K extends keyof T> = {    [P in K]: T[P];};

圖片

8.Omit<Type, Keys>

通過從 Type 中選擇所有屬性然后刪除 Keys(字符串文字或字符串文字的聯(lián)合)來構(gòu)造一個類型。

/** * Construct a type with the properties of T except for those  * in type K.  * typescript/lib/lib.es5.d.ts */type Omit<T, K extends keyof any> = Pick<T, Exclude<keyof T, K>>;

9. NonNullable<Type>

通過從 Type 中排除 null 和 undefined 來構(gòu)造一個類型。

/** * Exclude null and undefined from T. * typescript/lib/lib.es5.d.ts */type NonNullable<T> = T extends null | undefined ? never : T;

10. Parameters<Type>

從函數(shù)類型 Type 的參數(shù)中使用的類型構(gòu)造元組類型。

圖片

/** * Obtain the parameters of a function type in a tuple. * typescript/lib/lib.es5.d.ts */type Parameters<T extends (...args: any) => any> = T extends   (...args: infer P) => any ? P : never;

11. ReturnType<Type>

構(gòu)造一個由函數(shù) Type 的返回類型組成的類型。

/** * Obtain the return type of a function type. * typescript/lib/lib.es5.d.ts */type ReturnType<T extends (...args: any) => any> = T extends (...args: any) => infer R ? R : any;

12. Uppercase<StringType>

將字符串文字類型轉(zhuǎn)換為大寫。

圖片

13.小寫<StringType>

將字符串文字類型轉(zhuǎn)換為小寫。

圖片

14. 大寫<StringType>

將字符串文字類型的第一個字符轉(zhuǎn)換為大寫。

圖片

15. 取消大寫<StringType>

將字符串文字類型的第一個字符轉(zhuǎn)換為小寫。

圖片

除了上述這些實用程序類型之外,還有一些其他常用的 TypeScript 內(nèi)置實用程序類型,具體如下:

  • ConstructorParameters<Type>:根據(jù)構(gòu)造函數(shù)類型的類型構(gòu)造元組或數(shù)組類型。它產(chǎn)生一個包含所有參數(shù)類型的元組類型(如果 Type 不是函數(shù),則類型 never )。
  • InstanceType<Type>:構(gòu)造一個由Type中構(gòu)造函數(shù)的實例類型組成的類型。
  • ThisParameterType<Type>:為函數(shù)類型提取此參數(shù)的類型,如果函數(shù)類型沒有此參數(shù),則為未知。

本文介紹的實用程序類型在內(nèi)部使用了有關(guān)映射類型、條件類型和推斷類型推斷的知識。如果你對映射類型和條件類型不熟悉,后面我將繼續(xù)分享一些這個方面的知識。

責(zé)任編輯:華軒 來源: web前端開發(fā)
相關(guān)推薦

2023-02-28 15:20:31

TypeScript開發(fā)編程

2022-09-20 12:59:36

JavaScript函數(shù)

2010-07-30 13:58:20

DB2 實用程序

2020-05-11 12:13:16

GNULinux

2010-02-04 15:29:40

Android實用程序

2011-05-27 15:24:28

DB2

2018-08-31 08:42:48

LinuxUnix實用程序

2010-11-30 15:04:31

Office Web

2010-09-30 15:29:56

DB2查詢管理

2010-07-26 09:14:22

Perl命令行

2010-11-26 14:21:49

Office 套件

2010-11-30 15:18:32

Office

2022-06-16 11:01:22

數(shù)據(jù)庫SQL

2010-11-30 15:20:53

Office

2010-11-26 13:58:54

2020-04-26 12:05:53

機(jī)器學(xué)習(xí)工具人工智能

2010-04-14 08:49:43

Oracle數(shù)據(jù)庫系統(tǒng)

2022-08-29 19:52:34

socat命令Linux

2020-07-14 19:45:13

LinuxgPhoto2備份手機(jī)存儲

2024-01-08 13:48:00

物聯(lián)網(wǎng)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 亚洲黄色国产 | 午夜精品视频在线观看 | 91观看| 中文字幕高清 | 特黄级国产片 | 国产高潮好爽受不了了夜夜做 | 精品一区久久 | 精品一区二区久久久久久久网站 | 日韩一二区在线观看 | 国产精品区二区三区日本 | 国产在线观看av | 成人一区二区三区 | 欧美日韩国产精品一区二区 | 久久99精品久久久久婷婷 | 在线播放国产一区二区三区 | 91久久精品国产91久久性色tv | 激情欧美一区二区三区中文字幕 | 玖玖视频国产 | 日韩欧美在线免费观看 | 久久精品播放 | 久久精品亚洲一区 | 亚洲激情自拍偷拍 | 久久小视频 | 中文字幕第十一页 | 色综合久久天天综合网 | 一级毛片色一级 | 亚洲一区国产精品 | 福利精品 | 一区二区视频 | 日韩在线精品强乱中文字幕 | xxxxx黄色片 欧美一区免费 | 欧美不卡| 成人亚洲精品久久久久软件 | 成人国产精品色哟哟 | 在线观看免费av网站 | 老外几下就让我高潮了 | 亚洲综合色视频在线观看 | 久久精品高清视频 | 91免费电影 | 欧美一区二区大片 | 91视频进入|