TypeScript高級(jí)類型

一、聯(lián)合類型

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

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

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

二、交叉類型

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

對(duì)一個(gè)對(duì)象進(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});

三、字面量類型

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

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

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

四、類型別名

有的時(shí)候類型標(biāo)注比較復(fù)雜,這個(gè)時(shí)候我們可以類型標(biāo)注起一個(gè)相對(duì)簡(jiǎn)單的名字

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 自動(dòng)合并,利于擴(kuò)展

type

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

七、類型推導(dǎo)

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

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

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

八、類型斷言

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

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

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

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

或者

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

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

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

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,646評(píng)論 6 533
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,595評(píng)論 3 418
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事?!?“怎么了?”我有些...
    開封第一講書人閱讀 176,560評(píng)論 0 376
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,035評(píng)論 1 314
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 71,814評(píng)論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,224評(píng)論 1 324
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,301評(píng)論 3 442
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,444評(píng)論 0 288
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,988評(píng)論 1 335
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 40,804評(píng)論 3 355
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 42,998評(píng)論 1 370
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,544評(píng)論 5 360
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,237評(píng)論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,665評(píng)論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,927評(píng)論 1 287
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 51,706評(píng)論 3 393
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 47,993評(píng)論 2 374

推薦閱讀更多精彩內(nèi)容

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