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)系作者
  • 序言:七十年代末爽柒,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子者填,更是在濱河造成了極大的恐慌浩村,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,561評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件占哟,死亡現(xiàn)場(chǎng)離奇詭異心墅,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)榨乎,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,218評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門怎燥,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人谬哀,你說我怎么就攤上這事刺覆。” “怎么了史煎?”我有些...
    開封第一講書人閱讀 157,162評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵谦屑,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我篇梭,道長(zhǎng)氢橙,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,470評(píng)論 1 283
  • 正文 為了忘掉前任恬偷,我火速辦了婚禮悍手,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘袍患。我一直安慰自己坦康,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,550評(píng)論 6 385
  • 文/花漫 我一把揭開白布诡延。 她就那樣靜靜地躺著滞欠,像睡著了一般。 火紅的嫁衣襯著肌膚如雪肆良。 梳的紋絲不亂的頭發(fā)上筛璧,一...
    開封第一講書人閱讀 49,806評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音惹恃,去河邊找鬼夭谤。 笑死,一個(gè)胖子當(dāng)著我的面吹牛巫糙,可吹牛的內(nèi)容都是我干的朗儒。 我是一名探鬼主播,決...
    沈念sama閱讀 38,951評(píng)論 3 407
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼采蚀!你這毒婦竟也來了疲牵?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,712評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤榆鼠,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后亥鸠,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體妆够,經(jīng)...
    沈念sama閱讀 44,166評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,510評(píng)論 2 327
  • 正文 我和宋清朗相戀三年负蚊,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了神妹。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,643評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡家妆,死狀恐怖鸵荠,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情伤极,我是刑警寧澤蛹找,帶...
    沈念sama閱讀 34,306評(píng)論 4 330
  • 正文 年R本政府宣布,位于F島的核電站哨坪,受9級(jí)特大地震影響庸疾,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜当编,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,930評(píng)論 3 313
  • 文/蒙蒙 一届慈、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧忿偷,春花似錦金顿、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,745評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至芜壁,卻和暖如春礁凡,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背慧妄。 一陣腳步聲響...
    開封第一講書人閱讀 31,983評(píng)論 1 266
  • 我被黑心中介騙來泰國(guó)打工顷牌, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人塞淹。 一個(gè)月前我還...
    沈念sama閱讀 46,351評(píng)論 2 360
  • 正文 我出身青樓窟蓝,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親饱普。 傳聞我的和親對(duì)象是個(gè)殘疾皇子运挫,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,509評(píng)論 2 348

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

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