15 種最常用的TypeScript 實用程序類型
在使用TypeScript的過程中,我們是面向類型編程的。為了滿足不同的工作場景,我們需要對已知的類型進行改造。為了方便 TypeScript 用戶,TypeScript 開發(fā)團隊為我們提供了很多有用的內(nèi)置實用類型。有了這些實用類型,我們可以很方便地轉(zhuǎn)換類型、提取類型、排除類型,或者獲取函數(shù)的參數(shù)類型或返回值類型。
在今天的文章中,我從 TypeScript 內(nèi)置的實用類型中挑選了 15 個非常有用的類型,分別介紹了它們的用法和內(nèi)部工作原理。看完本文,相信你能真正掌握這些內(nèi)置實用類型的用法。
1. Partial<Type>
構(gòu)造一個 Type 的所有屬性都設置為可選的類型。
2. Required<Type>
構(gòu)造一個類型,該類型由設置為必需的 Type 的所有屬性組成,與 Partial 相反。
3. Readonly<Type>
構(gòu)造一個 Type 的所有屬性都設置為只讀的類型,這意味著不能重新分配構(gòu)造類型的屬性。
4. Record<Key?s, Type>
構(gòu)造一個對象類型,其屬性鍵為 Keys,其屬性值為 Type,該實用程序可用于將一種類型的屬性映射到另一種類型。
5. Exclude<UnionType, ExcludedMembers>
通過從 UnionType 中排除所有可分配給 ExcludedMembers 的聯(lián)合成員來構(gòu)造一個類型。
6. Extract<Type, Union>
通過從 Type 中提取可分配給 Union 的所有聯(lián)合成員來構(gòu)造一個類型。
7. Pick<Type, Keys>
通過從 Type 中選擇一組屬性鍵(字符串文字或字符串文字的并集)來構(gòu)造一個類型。
8. Omit<Type, Keys>
通過從 Type 中選擇所有屬性然后刪除鍵(字符串文字或字符串文字的并集)來構(gòu)造一個類型。
9. NonNullable<Type>
通過從 Type 中排除 null 和 undefined 來構(gòu)造一個類型。
10. Parameters<Type>
根據(jù)函數(shù)類型 Type 的參數(shù)中使用的類型構(gòu)造元組類型。
11. ReturnType<Type>
構(gòu)造一個由函數(shù) Type 的返回類型組成的類型。
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)容對你有用的話,請記得點贊我,關注我,并將這篇文章分享給你的朋友,也許能夠幫助到他。