Typescript 中 interface 和 type 的區(qū)別

相同點(diǎn):

都可以描述一個(gè)對(duì)象或者函數(shù)

// interface
interface User {
 name: string
 age: number
}

interface SetUser {
 (name: string, age: number): void;
}

// type
type User = {
 name: string
 age: number
};

type SetUser = (name: string, age: number): void;

都允許拓展(extends)
interface 和 type 都可以拓展卧抗,并且兩者并不是相互獨(dú)立的扎瓶,也就是說 interface 可以 extends type, type 也可以 extends interface 。 雖然效果差不多文留,但是兩者語法不同泞边。

// interface extends interface
interface Name { 
 name: string; 
}
interface User extends Name { 
 age: number; 
}
// type extends type
type Name = { 
 name: string; 
}
type User = Name & { age: number };
// interface extends type
type Name = { 
 name: string; 
}
interface User extends Name { 
 age: number; 
}
// type extends interface
interface Name { 
 name: string; 
}
type User = Name & { 
 age: number; 
}
不同點(diǎn):

type 可以而 interface 不行
type 可以聲明基本類型別名,聯(lián)合類型裙犹,元組等類型

// 基本類型別名
type Name = string

// 聯(lián)合類型
interface Dog {
 wong();
}
interface Cat {
 miao();
}

type Pet = Dog | Cat

// 具體定義數(shù)組每個(gè)位置的類型
type PetList = [Dog, Pet]

type 語句中還可以使用 typeof 獲取實(shí)例的 類型進(jìn)行賦值

// 當(dāng)你想獲取一個(gè)變量的類型時(shí),使用 typeof
let div = document.createElement('div');
type B = typeof div

其他騷操作

type StringOrNumber = string | number; 
type Text = string | { text: string }; 
type NameLookup = Dictionary<string, Person>; 
type Callback<T> = (data: T) => void; 
type Pair<T> = [T, T]; 
type Coordinates = Pair<number>; 
type Tree<T> = T | { left: Tree<T>, right: Tree<T> };

interface 可以而 type 不行
interface 能夠聲明合并

interface User {
 name: string
 age: number
}

interface User {
 sex: string
}

/*
User 接口為 {
 name: string
 age: number
 sex: string 
}
*/

一般來說衔憨,如果不清楚什么時(shí)候用interface/type叶圃,能用 interface 實(shí)現(xiàn),就用 interface , 如果不能就用 type 践图。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末掺冠,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子码党,更是在濱河造成了極大的恐慌德崭,老刑警劉巖斥黑,帶你破解...
    沈念sama閱讀 211,639評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異眉厨,居然都是意外死亡锌奴,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,277評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門憾股,熙熙樓的掌柜王于貴愁眉苦臉地迎上來鹿蜀,“玉大人,你說我怎么就攤上這事服球〕芾眩” “怎么了?”我有些...
    開封第一講書人閱讀 157,221評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵有咨,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我蒸健,道長(zhǎng)座享,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,474評(píng)論 1 283
  • 正文 為了忘掉前任似忧,我火速辦了婚禮渣叛,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘盯捌。我一直安慰自己淳衙,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,570評(píng)論 6 386
  • 文/花漫 我一把揭開白布饺著。 她就那樣靜靜地躺著箫攀,像睡著了一般。 火紅的嫁衣襯著肌膚如雪幼衰。 梳的紋絲不亂的頭發(fā)上靴跛,一...
    開封第一講書人閱讀 49,816評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音渡嚣,去河邊找鬼梢睛。 笑死,一個(gè)胖子當(dāng)著我的面吹牛识椰,可吹牛的內(nèi)容都是我干的绝葡。 我是一名探鬼主播,決...
    沈念sama閱讀 38,957評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼腹鹉,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼藏畅!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起功咒,我...
    開封第一講書人閱讀 37,718評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤墓赴,失蹤者是張志新(化名)和其女友劉穎竞膳,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體诫硕,經(jīng)...
    沈念sama閱讀 44,176評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡坦辟,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,511評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了章办。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片锉走。...
    茶點(diǎn)故事閱讀 38,646評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖藕届,靈堂內(nèi)的尸體忽然破棺而出挪蹭,到底是詐尸還是另有隱情,我是刑警寧澤休偶,帶...
    沈念sama閱讀 34,322評(píng)論 4 330
  • 正文 年R本政府宣布梁厉,位于F島的核電站隔心,受9級(jí)特大地震影響迷捧,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜垃它,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,934評(píng)論 3 313
  • 文/蒙蒙 一碱妆、第九天 我趴在偏房一處隱蔽的房頂上張望肉盹。 院中可真熱鬧,春花似錦疹尾、人聲如沸上忍。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,755評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽窍蓝。三九已至,卻和暖如春繁成,著一層夾襖步出監(jiān)牢的瞬間它抱,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,987評(píng)論 1 266
  • 我被黑心中介騙來泰國打工朴艰, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留观蓄,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,358評(píng)論 2 360
  • 正文 我出身青樓祠墅,卻偏偏與公主長(zhǎng)得像侮穿,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子毁嗦,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,514評(píng)論 2 348

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