自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

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

開發(fā) 前端
在今天的文章中,我從 TypeScript 內(nèi)置的實用類型中挑選了 15 個非常有用的類型,分別介紹了它們的用法和內(nèi)部工作原理。看完本文,相信你能真正掌握這些內(nèi)置實用類型的用法。

在使用TypeScript的過程中,我們是面向類型編程的。為了滿足不同的工作場景,我們需要對已知的類型進行改造。為了方便 TypeScript 用戶,TypeScript 開發(fā)團隊為我們提供了很多有用的內(nèi)置實用類型。有了這些實用類型,我們可以很方便地轉(zhuǎn)換類型、提取類型、排除類型,或者獲取函數(shù)的參數(shù)類型或返回值類型。

在今天的文章中,我從 TypeScript 內(nèi)置的實用類型中挑選了 15 個非常有用的類型,分別介紹了它們的用法和內(nèi)部工作原理。看完本文,相信你能真正掌握這些內(nèi)置實用類型的用法。

1. Partial<Type>

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

/**
* 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)造一個類型,該類型由設置為必需的 Type 的所有屬性組成,與 Partial 相反。

圖片

/**
* 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 的所有屬性都設置為只讀的類型,這意味著不能重新分配構(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<Key?s, 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 中選擇一組屬性鍵(字符串文字或字符串文字的并集)來構(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 中選擇所有屬性然后刪除鍵(字符串文字或字符串文字的并集)來構(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>

根據(jù)函數(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. Lowercase<StringType>

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

圖片

14. Capitalize<StringType>

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

圖片

15. Uncapitalize<StringType>

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

圖片

除了上面介紹的這些實用類型外,其他常用的 TypeScript 內(nèi)置實用類型如下:

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

總結(jié)

本文介紹的實用程序類型屬于內(nèi)部使用,有關映射類型、條件類型和推斷類型推斷的知識。如果您不熟悉映射類型和條件類型,我強烈建議您去學習一下它的相關知識。

如果你覺得今天的內(nèi)容對你有用的話,請記得點贊我,關注我,并將這篇文章分享給你的朋友,也許能夠幫助到他。

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

2022-10-24 15:29:34

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-11-26 14:21:49

Office 套件

2010-11-30 15:18:32

Office

2010-07-26 09:14:22

Perl命令行

2022-06-16 11:01:22

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

2010-11-30 15:20:53

Office

2020-04-26 12:05:53

機器學習工具人工智能

2010-11-26 13:58:54

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備份手機存儲

2024-01-08 13:48:00

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

51CTO技術棧公眾號