TypeScript高級類型

一、聯(lián)合類型

聯(lián)合類型也可以稱為多選類型,當(dāng)我們希望標(biāo)注一個變量為多個類型之一時可以選擇聯(lián)合類型標(biāo)注,或 的關(guān)系

function css(ele: Element, attr: string, value: string|number) {
    // ...
}

let box = document.querySelector('.box');
// document.querySelector 方法返回值就是一個聯(lián)合類型 string|number
if (box) {
    // ts 會提示有 null 的可能性,加上判斷更嚴(yán)謹(jǐn)
    css(box, 'width', '100px');
    css(box, 'opacity', 1);
    css(box, 'opacity', [1,2]);  // 錯誤
}

二、交叉類型

交叉類型也可以稱為合并類型,可以把多種類型合并到一起成為一種新的類型,并且 的關(guān)系

對一個對象進(jìn)行擴(kuò)展:

interface o1 {x: number, y: string};
interface o2 {z: number};

let newObj: o1 & o2 = Object.assign({}, {x:1,y:'2'}, {z: 100});

三、字面量類型

有的時候,我們希望標(biāo)注的不是某個類型,而是一個固定值,就可以使用字面量類型,配合聯(lián)合類型會更有用

function setPosition(ele: Element, direction: 'left' | 'top' | 'right' | 'bottom') {
    // ...
}

// ok
box && setDirection(box, 'bottom');
// error
box && setDirection(box, 'other');

四、類型別名

有的時候類型標(biāo)注比較復(fù)雜,這個時候我們可以類型標(biāo)注起一個相對簡單的名字

type dir = 'left' | 'top' | 'right' | 'bottom';
function setPosition(ele: Element, direction: dir) {
    // ...
}

五、使用類型別名定義函數(shù)類型

這里需要注意一下,如果使用 type 來定義函數(shù)類型,和接口有點(diǎn)不太相同

type callback = (a: string) => string;
let fn: callback = function(a) {};

// 或者直接
let fn: (a: string) => string = function(a) {}

六、interface 與 type 的區(qū)別

interface

  • 只能描述 object/class/function 的類型
  • 同名 interface 自動合并,利于擴(kuò)展

type

  • 不能重名
  • 能描述所有數(shù)據(jù)

七、類型推導(dǎo)

每次都顯式標(biāo)注類型會比較麻煩,TypeScript 提供了一種更加方便的特性:類型推導(dǎo)。TypeScript 編譯器會根據(jù)當(dāng)前上下文自動的推導(dǎo)出對應(yīng)的類型標(biāo)注,這個過程發(fā)生在:

  • 初始化變量
  • 設(shè)置函數(shù)默認(rèn)參數(shù)值
  • 返回函數(shù)值
// 自動推斷 x 為 number類型
let x = 1;
// 不能將string類型"a"分配給number類型
x = 'a';

// 函數(shù)參數(shù)類型、函數(shù)返回值會根據(jù)對應(yīng)的默認(rèn)值和返回值進(jìn)行自動推斷
function fn(a = 1) {return a * a}

八、類型斷言

有的時候,我們可能標(biāo)注一個更加精確的類型(縮小類型標(biāo)注范圍),比如:

let img = document.querySelector('#img');

我們可以看到 img 的類型為 Element,而 Element 類型其實(shí)只是元素類型的通用類型,如果我們?nèi)ピL問 src 這個屬性是有問題的,我們需要把它的類型標(biāo)注得更為精確:HTMLImageElement 類型,這個時候,我們就可以使用類型斷言,它類似于一種 類型轉(zhuǎn)換:

let img = <HTMLImageElement>document.querySelector('#img');

或者

let img = document.querySelector('#img') as HTMLImageElement;

注意:斷言只是一種預(yù)判,并不會數(shù)據(jù)本身產(chǎn)生實(shí)際的作用,即:類似轉(zhuǎn)換,但并非真的轉(zhuǎn)換了

文章每周持續(xù)更新,可以微信搜索「 前端大集錦 」第一時間閱讀,回復(fù)【視頻】【書籍】領(lǐng)取200G視頻資料和30本PDF書籍資料

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 可以為null的類型 TypeScript具有兩種特殊的類型, null和 undefined,它們分別具有值nu...
    2o壹9閱讀 1,052評論 0 49
  • 一、交叉類型 交叉類型將多個類型合并為一個新的類型,新的具有所有參與合并的類型的特性,本質(zhì)上是一種并的操作。形式如...
    kuxingseng686閱讀 650評論 0 0
  • 交叉類型 交叉類型將多個類型合并為一個類型,相當(dāng)于新類型具有這多個類型的所有特性,相當(dāng)于是一種并的操作,通常在使用...
    這個前端不太冷閱讀 713評論 0 0
  • 數(shù)字字面量類型 TypeScript還具有數(shù)字字面量類型。 function rollDie(): 1 | 2 |...
    2o壹9閱讀 878評論 2 50
  • 交叉類型(Intersection Types) 交叉類型是將多個類型合并為一個類型。 這讓我們可以把現(xiàn)有的多種類...
    2o壹9閱讀 780評論 0 49

友情鏈接更多精彩內(nèi)容