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

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

開發 前端
在今天的文章中,我從 TypeScript 內置的實用類型中挑選了 15 個非常有用的類型,分別介紹了它們的用法和內部工作原理??赐瓯疚?,相信你能真正掌握這些內置實用類型的用法。

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

在今天的文章中,我從 TypeScript 內置的實用類型中挑選了 15 個非常有用的類型,分別介紹了它們的用法和內部工作原理??赐瓯疚模嘈拍隳苷嬲莆者@些內置實用類型的用法。

1. Partial<Type>

構造一個 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>

構造一個類型,該類型由設置為必需的 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>

構造一個 Type 的所有屬性都設置為只讀的類型,這意味著不能重新分配構造類型的屬性。

/**
* 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>

構造一個對象類型,其屬性鍵為 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 的聯合成員來構造一個類型。

圖片

/**
* 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 的所有聯合成員來構造一個類型。

圖片

/**
* 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 中選擇一組屬性鍵(字符串文字或字符串文字的并集)來構造一個類型。

圖片

/**
* 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 中選擇所有屬性然后刪除鍵(字符串文字或字符串文字的并集)來構造一個類型。

圖片

/**
* 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 來構造一個類型。

圖片

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

10. Parameters<Type>

根據函數類型 Type 的參數中使用的類型構造元組類型。

圖片

/**
* 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>

構造一個由函數 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>

將字符串文字類型轉換為大寫。

圖片

13. Lowercase<StringType>

將字符串文字類型轉換為小寫。

圖片

14. Capitalize<StringType>

將字符串文字類型的第一個字符轉換為大寫。

圖片

15. Uncapitalize<StringType>

將字符串文字類型的第一個字符轉換為小寫。

圖片

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

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

總結

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

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

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

2022-10-24 15:29:34

TypeScript開發程序類型

2022-09-20 12:59:36

JavaScript函數

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-30 15:18:32

Office

2010-11-26 14:21:49

Office 套件

2022-06-16 11:01:22

數據庫SQL

2010-11-30 15:20:53

Office

2010-11-26 13:58:54

2020-04-26 12:05:53

機器學習工具人工智能

2010-04-14 08:49:43

Oracle數據庫系統

2022-08-29 19:52:34

socat命令Linux

2020-07-14 19:45:13

LinuxgPhoto2備份手機存儲

2024-01-08 13:48:00

物聯網
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 精品欧美一区免费观看α√ | 日韩午夜精品 | 欧美日韩在线精品 | 欧美极品少妇xxxxⅹ免费视频 | 精品粉嫩aⅴ一区二区三区四区 | 秋霞精品 | 性一交一乱一伦视频免费观看 | 精品久久99| 欧美黑人一级爽快片淫片高清 | 99pao成人国产永久免费视频 | 国产一区二 | 日日爽 | 美女在线视频一区二区三区 | 99爱国产| 日韩一区二区久久 | 久久久久国产精品 | 欧美一级片在线播放 | 97色在线视频 | 久久久久久国产精品免费免费男同 | 欧美精品网 | ririsao久久精品一区 | 成人国产一区二区三区精品麻豆 | 久久机热 | 午夜性视频 | 成人免费黄色 | 91精品久久久 | 中文字幕一区在线观看视频 | 91精品久久久久 | 国产成人精品一区二区三 | 欧美国产视频 | 欧美日韩三区 | 精品无码久久久久久久动漫 | 国产在线精品区 | 超碰在线网站 | 天天操天天操 | 91精品国产综合久久久久 | 日韩精品无码一区二区三区 | 欧美大片久久久 | 91精品国产综合久久久久久首页 | 亚洲国产精品99久久久久久久久 | 精品一区二区三区免费毛片 |