我們?cè)谑褂?TypeScript 的過(guò)程中,我們是面向類(lèi)型編程的,為了滿足不同的工作場(chǎng)景,我們需要對(duì)已知類(lèi)型進(jìn)行改造。
為了方便 TypeScript 用戶,TypeScript 開(kāi)發(fā)團(tuán)隊(duì)為我們提供了許多有用的內(nèi)置實(shí)用程序類(lèi)型。
通過(guò)這些實(shí)用類(lèi)型,我們可以輕松地轉(zhuǎn)換類(lèi)型、提取類(lèi)型、排除類(lèi)型,或者獲取函數(shù)的參數(shù)類(lèi)型或返回值類(lèi)型。
在本文中,我從 TypeScript 的內(nèi)置實(shí)用程序類(lèi)型中挑選了 15 種非常有用的類(lèi)型,并以圖像的形式介紹了它們的用法和內(nèi)部工作原理,看完這篇文章,相信你可以真正掌握這些內(nèi)置實(shí)用程序類(lèi)型的用法。
1.Partial
構(gòu)造一個(gè)類(lèi)型,其中 Type 的所有屬性都設(shè)置為可選。
2.Required
構(gòu)造一個(gè)類(lèi)型,該類(lèi)型由設(shè)置為 required Type 的所有屬性組成,部分的反義詞。
3.Readonly
構(gòu)造一個(gè) Type 的所有屬性都設(shè)置為 readonly 的類(lèi)型,這意味著構(gòu)造類(lèi)型的屬性不能被重新分配。
4.Record<keys, type="">
構(gòu)造一個(gè)對(duì)象類(lèi)型,其屬性鍵為 Keys,其屬性值為 Type,此實(shí)用程序可用于將一種類(lèi)型的屬性映射到另一種類(lèi)型。
5.Exclude<uniontype, excludedmembers="">
通過(guò)從 UnionType 中排除可分配給 ExcludedMembers 的所有聯(lián)合成員來(lái)構(gòu)造類(lèi)型。
6.Extract<type, union="">
通過(guò)從 Type 中提取所有可分配給 Union 的聯(lián)合成員來(lái)構(gòu)造一個(gè)類(lèi)型。
7.Pick<type, keys="">
通過(guò)從 Type 中選擇一組屬性 Keys(字符串文字或字符串文字的聯(lián)合)來(lái)構(gòu)造一個(gè)類(lèi)型。
8.Omit<type, keys="">
通過(guò)從 Type 中選擇所有屬性然后刪除 Keys(字符串文字或字符串文字的聯(lián)合)來(lái)構(gòu)造一個(gè)類(lèi)型。
9.NonNullable
通過(guò)從 Type 中排除 null 和 undefined 來(lái)構(gòu)造一個(gè)類(lèi)型。
10.Parameters
從函數(shù)類(lèi)型 Type 的參數(shù)中使用的類(lèi)型構(gòu)造元組類(lèi)型。
11.ReturnType
構(gòu)造一個(gè)由函數(shù) Type 的返回類(lèi)型組成的類(lèi)型。
12.Uppercase
將字符串文字類(lèi)型轉(zhuǎn)換為大寫(xiě)。
13.小寫(xiě)
將字符串文字類(lèi)型轉(zhuǎn)換為小寫(xiě)。
14.大寫(xiě)
將字符串文字類(lèi)型的第一個(gè)字符轉(zhuǎn)換為大寫(xiě)。
15.取消大寫(xiě)
將字符串文字類(lèi)型的第一個(gè)字符轉(zhuǎn)換為小寫(xiě)。
除了上述這些實(shí)用程序類(lèi)型之外,還有一些其他常用的 TypeScript 內(nèi)置實(shí)用程序類(lèi)型,具體如下:
ConstructorParameters:根據(jù)構(gòu)造函數(shù)類(lèi)型的類(lèi)型構(gòu)造元組或數(shù)組類(lèi)型。它產(chǎn)生一個(gè)包含所有參數(shù)類(lèi)型的元組類(lèi)型(如果 Type 不是函數(shù),則類(lèi)型 never )。
InstanceType:構(gòu)造一個(gè)由Type中構(gòu)造函數(shù)的實(shí)例類(lèi)型組成的類(lèi)型。
ThisParameterType:為函數(shù)類(lèi)型提取此參數(shù)的類(lèi)型,如果函數(shù)類(lèi)型沒(méi)有此參數(shù),則為未知。