比同事更秀? TS 這七個方法,你需要知道的!
TypeScript 中的類型系統(tǒng)是非常強大的。它為我們提供了類型安全。類型系統(tǒng)雖然受人喜愛,但如果我們不規(guī)劃和設(shè)計類型和接口,它也會讓我們的代碼變得混亂難讀。
泛型
避免代碼重復(fù)中,創(chuàng)建可重用的類型,是我們編寫簡潔代碼重要的一環(huán)。泛型是 TypeScript 的一個功能,它允許我們編寫可重用的類型??聪旅娴睦樱?/p>
- type Add<T> = (a: T, b: T) => T
- const addNumbers: Add<number> = (a, b) => {
- return a + b
- }
- const addStrings: Add<string> = (a, b) => {
- return a + b
- }
將正確的類型放入Add的泛型中,它可以被用來描述兩個數(shù)字的相加或兩個字符串的連接。我們不需要為每個函數(shù)寫一個類型,而只需要用泛型做一次。這不僅節(jié)省了我們的精力,而且還使我們的代碼更加簡潔,更不容易出錯。
實用類型
TypeScript 原生提供了幾個有用的實用類型來幫助我們進行一些常見的類型轉(zhuǎn)換。這些實用類型是全局可用的,它們都使用了泛型。
下面這7個是我經(jīng)常用到的。
1. Pick<Type, Keys>
Pick會從 Type 中挑選屬性集 Keys 來創(chuàng)建一個新的類型,Keys 可以是一個字符串字面或字符串字面的聯(lián)合。Keys 的值必須是 Type 的鍵,否則TypeScript編譯器會抱怨。當(dāng)你想通過從有很多屬性的對象中挑選某些屬性來創(chuàng)建更輕的對象時,這個實用類型特別有用。
- type User = {
- name: string
- age: number
- address: string
- occupation: string
- }
- type BasicUser = Pick<User, "name" | "age">
- // type BasicUser = {
- // name: string;
- // age: number;
- // }
2. Omit<Type, Keys>
Omit與Pick相反。Keys 不是說要保留哪些屬性,而是指要省略的屬性鍵集。當(dāng)我們只想從對象中刪除某些屬性并保留其他屬性時,這個會更有用。
- type User = {
- name: string
- age: number
- address: string
- occupation: string
- }
- type BasicUser = Omit<User, "address" | "occupation">
- // type BasicUser = {
- // name: string;
- // age: number;
- // }
3. Partial<Type>
Partial 構(gòu)造了一個類型,其所有的類型屬性都設(shè)置為可選。當(dāng)我們在編寫一個對象的更新邏輯時,這個可能非常有用。
- type User = {
- name: string
- age: number
- address: string
- occupation: string
- }
- type PartialUser = Partial<User>
- // type PartialUser = {
- // name?: string;
- // age?: number;
- // address?: string;
- // occupation?: string;
- // }
4. Required<Type>
Required與Partial相反。它構(gòu)造了一個類型的所有屬性都是必填的類型。它可以被用來確保在一個類型中沒有可選屬性出現(xiàn)。
- type PartialUser = {
- name: string
- age: number
- address?: string
- occupation?: string
- }
- type User = Required<PartialUser>
- // type User = {
- // name: string;
- // age: number;
- // address: string;
- // occupation: string;
- // }
5. Readonly<Type>
Readonly 構(gòu)建了一個類型,其類型的所有屬性被設(shè)置為只讀。重新分配新的值 TS 就會報錯。
- type User = {
- name: string
- age: number
- address: string
- occupation: string
- }
- type ReadOnlyUser = Readonly<User>
- const user: ReadOnlyUser = {
- name: "小智",
- age: 24,
- address: "廈門",
- occupation: "大遷世界"
- }
- user.name = "王大冶"
- // Cannot assign to 'name' because it is a read-only property.
7. ReturnType<Type>
ReturnType 從一個函數(shù)類型的返回類型構(gòu)建一個類型。當(dāng)我們處理來自外部庫的函數(shù)類型并希望基于它們建立自定義類型時,它是非常有用的。
- import axios from 'axios'
- type Response = ReturnType<typeof axios>
- function callAPI(): Response{
- return axios("url")
- }
除了上面提到的,還有其他實用類型可以幫助我們編寫更干凈代碼。關(guān)于實用工具類型的TypeScript文檔鏈接可以在這里找到。
https://www.typescriptlang.org/docs/handbook/utility-types.html
實用類型是TypeScript提供的非常有用的功能。開發(fā)人員應(yīng)該利用它們來避免硬編碼類型。要比同事更秀? 這些就是你需要知道的!
~完,我是刷碗智,準(zhǔn)備去去那個了,我們下期見!
作者:juno ng 譯者:前端小智
來源:medium 原文:https://medium.com/ng/7-utility-types-that-every-typescript-developer-should-know-788fe73421f1
【編輯推薦】