亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

深入理解TypeScript 類型兼容性

 更新時間:2024年01月17日 15:06:55   作者:前端玖耀里  
本文主要介紹了TypeScript 在函數(shù)、枚舉、類和泛型中的類型兼容性規(guī)則,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧

我們學(xué)習類型兼容性,就是在學(xué)習 TypeScript 在一個類型能否賦值給其他類型的規(guī)則。本節(jié)將會詳細介紹 TypeScript 在函數(shù)、枚舉、類和泛型中的類型兼容性規(guī)則。

1. 解釋

類型兼容性用于確定一個類型是否能賦值給其他類型。

TypeScript 的類型檢查機制都是為了讓開發(fā)者在編譯階段就可以直觀的發(fā)現(xiàn)代碼書寫問題,養(yǎng)成良好的代碼規(guī)范從而避免很多低級錯誤。

let address: string = 'Baker Street 221B'
let year: number = 2010
address = year // Error

代碼解釋: 第 3 行,類型 ‘number’ 不能賦值給類型 ‘string’。

2. 結(jié)構(gòu)化

TypeScript 類型兼容性是基于結(jié)構(gòu)類型的;結(jié)構(gòu)類型只使用其成員來描述類型。

TypeScript 結(jié)構(gòu)化類型系統(tǒng)的基本規(guī)則是,如果 x 要兼容 y,那么 y 至少具有與 x 相同的屬性。比如:

interface User {
  name: string,
  year: number
}

let protagonist = {
  name: 'Sherlock·Holmes',
  year: 1854,
  address: 'Baker Street 221B'
}

let user: User = protagonist // OK

代碼解釋: 接口 User 中的每一個屬性在 protagonist 對象中都能找到對應(yīng)的屬性,且類型匹配。另外,可以看到 protagonist 具有一個額外的屬性 address,但是賦值同樣會成功。

3. 比較兩個函數(shù)

相對來講,在比較原始類型和對象類型的時候是比較容易理解的,難的是如何判斷兩個函數(shù)是否兼容。判斷兩個函數(shù)是否兼容,首先要看參數(shù)是否兼容,第二個還要看返回值是否兼容。

3.1 函數(shù)參數(shù)

先看一段代碼示例:

let fn1 = (a: number, b: string) => {}
let fn2 = (c: number, d: string, e: boolean) => {}

fn2 = fn1 // OK
fn1 = fn2 // Error

代碼解釋:

第 4 行,將 fn1 賦值給 fn2 成立是因為:

  • fn1 的每個參數(shù)均能在 fn2 中找到對應(yīng)類型的參數(shù)
  • 參數(shù)順序保持一致,參數(shù)類型對應(yīng)
  • 參數(shù)名稱不需要相同

第 5 行,將 fn2 賦值給 fn1 不成立,是因為 fn2 中的必須參數(shù)必須在 fn1 中找到對應(yīng)的參數(shù),顯然第三個布爾類型的參數(shù)在 fn1 中未找到。

參數(shù)類型對應(yīng)即可,不需要完全相同:

let fn1 = (a: number | string, b: string) => {}
let fn2 = (c: number, d: string, e: boolean) => {}

fn2 = fn1 // OK

代碼解釋: fn1 的第一個參數(shù)是 number 和 string 的聯(lián)合類型,可以對應(yīng) fn2 的第一個參數(shù)類型 number,所以第 4 行賦值正常。

3.2 函數(shù)返回值

創(chuàng)建兩個僅是返回值類型不同的函數(shù)

代碼解釋: 最后一行,函數(shù) x() 缺少 location 屬性,所以報錯。

類型系統(tǒng)強制源函數(shù)的返回值類型必須是目標函數(shù)返回值類型的子類型。由此可以得出如果目標函數(shù)的返回值類型是 void,那么源函數(shù)返回值可以是任意類型:

let x : () => void
let y = () => 'mybj'

x = y // OK

4. 枚舉的類型兼容性

枚舉與數(shù)字類型相互兼容:

enum Status {
  Pending,
  Resolved,
  Rejected
}

let current = Status.Pending
let num = 0

current = num
num = current

不同枚舉類型之間是不兼容的:

enum Status { Pending, Resolved, Rejected }
enum Color { Red, Blue, Green }

let current = Status.Pending
current = Color.Red // Error

5. 類的類型兼容性

類與對象字面量和接口的兼容性非常類似,但是類分實例部分和靜態(tài)部分。

比較兩個類類型數(shù)據(jù)時,只有實例成員會被比較,靜態(tài)成員和構(gòu)造函數(shù)不會比較。

class Animal {
  feet!: number
  constructor(name: string, numFeet: number) { }
}

class Size {
  feet!: number
  constructor(numFeet: number) { }
}

let a: Animal
let s: Size

a = s!  // OK
s = a  // OK

代碼解釋: 類 Animal 和類 Size 有相同的實例成員 feat 屬性,且類型相同,構(gòu)造函數(shù)參數(shù)雖然不同,但構(gòu)造函數(shù)不參與兩個類類型比較,所以最后兩行可以相互賦值。

類的私有成員和受保護成員會影響兼容性。 允許子類賦值給父類,但是不能賦值給其它有同樣類型的類。

class Animal {
  protected feet!: number
  constructor(name: string, numFeet: number) { }
}

class Dog extends Animal {}

let a: Animal
let d: Dog

a = d! // OK
d = a // OK

class Size {
  feet!: number
  constructor(numFeet: number) { }
}

let s: Size

a = s! // Error

代碼解釋:

第 13 行,子類可以賦值給父類。

第 14 行,父類之所以能夠給賦值給子類,是因為子類中沒有成員。

最后一行,因為類 Animal 中的成員 feet 是受保護的,所以不能賦值成功。

6. 泛型的類型兼容性

泛型的類型兼容性根據(jù)其是否被成員使用而不同。先看一段代碼示例:

interface Empty<T> {}

let x: Empty<number>
let y: Empty<string>

x = y! // OK

上面代碼里,x 和 y 是兼容的,因為它們的結(jié)構(gòu)使用類型參數(shù)時并沒有什么不同。但是當泛型被成員使用時:

interface NotEmpty<T> {
  data: T
}
let x: NotEmpty<number>
let y: NotEmpty<string>

x = y! // Error

代碼解釋: 因為第 4 行,泛型參數(shù)是 number 類型,第 5 行,泛型參數(shù)是 string 類型,所以最后一行賦值失敗。

如果沒有指定泛型類型的泛型參數(shù),會把所有泛型參數(shù)當成 any 類型比較

7. 小結(jié)

要充分利用 TypeScript 的類型檢查機制規(guī)范代碼,減少一些不必要的錯誤,這也是我們使用 TypeScript 的初衷。

到此這篇關(guān)于深入理解TypeScript 類型兼容性的文章就介紹到這了,更多相關(guān)TypeScript類型兼容性內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:

相關(guān)文章

  • JS一個簡單的注冊頁面實例

    JS一個簡單的注冊頁面實例

    下面小編就為大家?guī)硪黄狫S一個簡單的注冊頁面實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • JS實現(xiàn)點星星消除小游戲

    JS實現(xiàn)點星星消除小游戲

    這篇文章主要為大家詳細介紹了JS實現(xiàn)點星星消除小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • 生產(chǎn)制造追溯系統(tǒng)之在線打印功能

    生產(chǎn)制造追溯系統(tǒng)之在線打印功能

    這篇文章主要介紹了生產(chǎn)制造追溯系統(tǒng)之在線打印功能,本文圖文并茂給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下
    2019-06-06
  • JS擴展類,克隆對象與混合類實例分析

    JS擴展類,克隆對象與混合類實例分析

    這篇文章主要介紹了JS擴展類,克隆對象與混合類,通過自定義extend,clone與augment函數(shù)實例分析了類的擴展,對象的克隆與混合類相關(guān)實現(xiàn)與使用技巧,需要的朋友可以參考下
    2016-11-11
  • Javascript中查找不以XX字符結(jié)尾的單詞示例代碼

    Javascript中查找不以XX字符結(jié)尾的單詞示例代碼

    我在寫這篇文章之前花了2個多小時在弄正則表達式,下為大家介紹下具體的實現(xiàn)思路,感興趣的朋友可以參考下
    2013-10-10
  • JavaScript實現(xiàn)對下拉列表值進行排序的方法

    JavaScript實現(xiàn)對下拉列表值進行排序的方法

    這篇文章主要介紹了JavaScript實現(xiàn)對下拉列表值進行排序的方法,實例分析了javascript對下拉列表元素的遍歷與排序?qū)崿F(xiàn)技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-07-07
  • JavaScript判斷變量是否為數(shù)組的方法(Array)

    JavaScript判斷變量是否為數(shù)組的方法(Array)

    這篇文章主要介紹了JavaScript判斷變量是否為數(shù)組的方法(Array),涉及到j(luò)avascript 數(shù)組 變量相關(guān)知識,感興趣的朋友一起學(xué)習吧
    2016-02-02
  • 利用JS實現(xiàn)獲取當前系統(tǒng)電量情況

    利用JS實現(xiàn)獲取當前系統(tǒng)電量情況

    在前端瀏覽器中我們可以通過使用JavaScript的navigator.getBattery()方法來獲取當前系統(tǒng)的電池情況,本文將介紹如何使用這個API以及它在實際應(yīng)用中的使用,需要的可以參考下
    2023-12-12
  • 探究Javascript模板引擎mustache.js使用方法

    探究Javascript模板引擎mustache.js使用方法

    這篇文章主要為大家介紹了Javascript模板引擎mustache.js使用方法,mustache.js是一個簡單強大的Javascript模板引擎,使用它可以簡化在js代碼中的html編寫,壓縮后只有9KB,非常值得在項目中使用,感興趣的小伙伴們可以參考一下
    2016-01-01
  • 基于js實現(xiàn)微信發(fā)送好友如何分享到朋友圈、微博

    基于js實現(xiàn)微信發(fā)送好友如何分享到朋友圈、微博

    微信瀏覽器內(nèi)置了javascript私有對象WeixinJSBridge,可以實現(xiàn)發(fā)送給朋友、分享到朋友圈、分享到微博等功能,本篇文章給大家介紹基于js實現(xiàn)微信發(fā)送給朋友如何分享到朋友圈、微博,感興趣的朋友一起學(xué)習吧
    2015-11-11

最新評論