91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

TypeScript中值得了解的方法有哪些

發布時間:2021-09-17 11:06:39 來源:億速云 閱讀:128 作者:小新 欄目:web開發

小編給大家分享一下TypeScript中值得了解的方法有哪些,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

TypeScript 中的類型系統是非常強大的。它為我們提供了類型安全。類型系統雖然受人喜愛,但如果我們不規劃和設計類型和接口,它也會讓我們的代碼變得混亂難讀。

泛型

避免代碼重復中,創建可重用的類型,是我們編寫簡潔代碼重要的一環。泛型是 TypeScript 的一個功能,它允許我們編寫可重用的類型。看下面的例子:

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的泛型中,它可以被用來描述兩個數字的相加或兩個字符串的連接。我們不需要為每個函數寫一個類型,而只需要用泛型做一次。這不僅節省了我們的精力,而且還使我們的代碼更加簡潔,更不容易出錯。

實用類型

TypeScript 原生提供了幾個有用的實用類型來幫助我們進行一些常見的類型轉換。這些實用類型是全局可用的,它們都使用了泛型。

下面這7個是我經常用到的。

1. Pick<Type, Keys>

Pick會從 Type 中挑選屬性集 Keys 來創建一個新的類型,Keys 可以是一個字符串字面或字符串字面的聯合。Keys 的值必須是 Type 的鍵,否則TypeScript編譯器會抱怨。當你想通過從有很多屬性的對象中挑選某些屬性來創建更輕的對象時,這個實用類型特別有用。

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>

OmitPick相反。 Keys 不是說要保留哪些屬性,而是指要省略的屬性鍵集。 當我們只想從對象中刪除某些屬性并保留其他屬性時,這個會更有用。

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 構造了一個類型,其所有的類型屬性都設置為可選。當我們在編寫一個對象的更新邏輯時,這個可能非常有用。

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>

RequiredPartial相反。它構造了一個類型的所有屬性都是必填的類型。它可以被用來確保在一個類型中沒有可選屬性出現。

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 構建了一個類型,其類型的所有屬性被設置為只讀。重新分配新的值 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.

6. ReturnType<Type>

ReturnType 從一個函數類型的返回類型構建一個類型。當我們處理來自外部庫的函數類型并希望基于它們建立自定義類型時,它是非常有用的。

import axios from 'axios'

type Response = ReturnType<typeof axios>

function callAPI(): Response{
  return axios("url")
}

除了上面提到的,還有其他實用類型可以幫助我們編寫更干凈代碼。關于實用工具類型的TypeScript文檔鏈接可以在這里找到。

以上是“TypeScript中值得了解的方法有哪些”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

肥东县| 阿拉善左旗| 浦东新区| 铜川市| 德格县| 田林县| 普陀区| 青铜峡市| 东明县| 酒泉市| 侯马市| 辰溪县| 图木舒克市| 临沂市| 南丰县| 香格里拉县| 正定县| 台北县| 和平区| 阜平县| 陈巴尔虎旗| 珲春市| 伊川县| 绥中县| 外汇| 瑞丽市| 三门峡市| 惠来县| 张家港市| 泾源县| 许昌县| 南开区| 永宁县| 炉霍县| 乡宁县| 宜州市| 安泽县| 襄城县| 龙州县| 台中市| 博客|