精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

TypeScript 中 interface 和 type 的區別,你真的懂了嗎?

開發 前端
在寫 ts 相關代碼的過程中,總能看到 interface 和 type 的身影。它們的作用好像都一樣的,相同的功能用哪一個都可以實現,也都很好用,所以也很少去真正的理解它們之間到底有啥區別, 分別在什么場景下使用,將自己學習的內容記錄分享一下。

類型別名 type

首先認識一下什么是類型別名?

類型別名用來給一個類型起個新名字,使用 type 創建類型別名,類型別名不僅可以用來表示基本類型,還可以用來表示對象類型、聯合類型、元組和交集。讓我們看一些例子:

type userName = string; // 基本類型
type userId = string | number; // 聯合類型
type arr = number[];
// 對象類型
type Person = {
id: userId; // 可以使用定義類型
name: userName;
age: number;
gender: string;
isWebDev: boolean;
};
// 范型
type Tree<T> = { value: T };
const user: Person = {
id: "901",
name: "椿",
age: 22,
gender: "女",
isWebDev: false,
};
const numbers: arr = [1, 8, 9];

接口 interface

接口是命名數據結構(例如對象)的另一種方式;與type 不同,interface僅限于描述對象類型。

接口的聲明語法也不同于類型別名的聲明語法。讓我們將上面的類型別名 Person 重寫為接口聲明:

interface Person {
id: userId;
name: userName;
age: number;
gender: string;
isWebDev: boolean;
}

interface和type的相似之處

在討論二者區別之前, 首先看一下二者的相似之處(為何開發中,我們覺得用哪個都一樣)

都可以描述 Object和Function

兩者都可以用來描述對象或函數,但語法不同:

Type

type Point = {
x: number;
y: number;
};
type SetPoint = (x: number, y: number) => void;

Interface

interface Point {
x: number;
y: number;
}
interface SetPoint {
(x: number, y: number): void;
}

二者都可以被繼承

interface 和 type 都可以繼承。

另一個值得注意的是,接口和類型別名并不互斥。類型別名可以繼承接口,反之亦然。只是在實現形式上,稍微有些差別。

interface 繼承 interface

interface Person{
name:string
}
interface Student extends Person { stuNo: number }

interface 繼承 type

type Person{
name:string
}
interface Student extends Person { stuNo: number }

type 繼承 type

type Person{
name:string
}
type Student = Person & { stuNo: number }

type 繼承 interface

interface Person{
name:string
}
type Student = Person & { stuNo: number }

實現 implements

類可以實現interface 以及 type(除聯合類型外)

interface ICat{
setName(name:string): void;
}
class Cat implements ICat{
setName(name:string):void{
// todo
}
}
// type
type ICat = {
setName(name:string): void;
}
class Cat implements ICat{
setName(name:string):void{
// todo
}
}

上面提到了特殊情況,類無法實現聯合類型, 是什么意思呢?

type Person = { name: string; } | { setName(name:string): void };
// 無法對聯合類型Person進行實現
// error: A class can only implement an object type or intersection of object types with statically known members.
class Student implements Person {
name= "張三";
setName(name:string):void{
// todo
}
}

上面聊了interface與 type的相似之處, 接下來就來看看他們的區別。

二者區別

1. 定義基本類型別名

type可以定義基本類型別名, 但是interface無法定義,如:

type userName = string
type stuNo = number
...

2. 聲明聯合類型

type可以聲明聯合類型, 例如:

type Student = {stuNo: number} | {classId: number}

3. 聲明元組

type可以聲明 元組類型:

type Data = [number, string];

以上都是 type能做到, 而interface做不到的, 接下來聊聊type做不到的

4. 聲明合并

如果你多次聲明一個同名的接口,TypeScript 會將它們合并到一個聲明中,并將它們視為一個接口。這稱為聲明合并, 例如:

interface Person { name: string }
interface Person { age: number }
let user: Person = {
name: "Tolu",
age: 0,
};

這種情況下,如果是type的話,重復使用Person是會報錯的:

type Person { name: string };  
// Error: 標識符“Person”重復。ts(2300)
type Person { age: number }

5. 索引簽名問題

如果你經常使用TypeScript, 一定遇到過相似的錯誤:

Type 'xxx' is not assignable to type 'yyy'

Index signature is missing in type 'xxx'.

看個例子來理解問題:

interface propType{
[key: string] : string
}
let props: propType
type dataType = {
title: string
}
interface dataType1 {
title: string
}
const data: dataType = {title: "訂單頁面"}
const data1: dataType1 = {title: "訂單頁面"}
props = data
// Error:類型“dataType1”不可分配給類型“propType”; 類型“dataType1”中缺少索引簽名
props = data1

我們發現dataType和dataType1對應的類型一樣,但是interface定義的就賦值失敗,是什么原因呢?剛開始百思不解,最后我在 stack overflow上找到了一個相似的問題:

image.png

并且很幸運的找到了有效的答案:

image.png

翻譯過來的大致意思就是:

Record<string,string>與{[key:string]:string}相同。只有當該類型的所有屬性都已知并且可以對照該索引簽名進行檢查時,才允許將子集分配給該索引簽名類型。在您的例子中,從exampleType到Record<string,string>的所有內容都是可分配的。這只能針對對象字面量類型進行檢查,因為一旦聲明了對象字面量類型,就無法更改它們。因此,索引簽名是已知的。

相反,在你使用interface去聲明變量時,它們在那一刻類型并不是最終的類型。由于interfac可以進行聲明合并,所以總有可能將新成員添加到同一個interface定義的類型上。

再結合??第4點 聲明合并的講解, 這樣就很好理解了。就是說interface定義的類型是不確定的, 后面再來一個:

interface propType{
title:number
}

這樣propType類型就被改變了。

總結

官方推薦用 interface,其他無法滿足需求的情況下用 type。

但其實,因為 聯合類型 和 交叉類型 是很常用的,所以避免不了大量使用 type 的場景,一些復雜類型也需要通過組裝后形成類型別名來使用。

所以,如果想保持代碼統一,還是可選擇使用 type。通過上面的對比,類型別名 其實可涵蓋 interface 的大部分場景。

對于 React 組件中 props及 state,使用 type ,這樣能夠保證使用組件的地方不能隨意在上面添加屬性。如果有自定義需求,可通過 HOC二次封裝。

編寫三方庫時使用interface,其更加靈活自動的類型合并可應對未知的復雜使用場景。

責任編輯:龐桂玉 來源: 前端開發
相關推薦

2022-04-07 08:20:22

typeinterface前端

2022-09-02 09:02:44

TypeInterface

2013-12-26 09:44:30

互聯網物聯網區別

2022-03-08 15:01:48

負載均衡IP服務器

2022-07-27 08:01:29

CMS垃圾回收器

2021-06-23 08:01:18

TypeScript interface type

2021-08-05 08:32:45

TypeScript InterfaceType

2022-04-07 16:03:36

JavaScriptTypeScript

2024-03-05 18:19:07

localhostLinux數據庫

2020-09-23 09:08:05

typescript

2024-08-12 15:23:43

LangChain

2023-10-27 07:39:44

IOC容器Spring

2022-03-13 18:53:31

interfacetypeTypeScript

2022-05-15 21:52:04

typeTypeScriptinterface

2018-10-20 16:05:12

iOSAPP開發

2021-10-10 20:36:49

Android Root權限

2021-10-12 10:50:31

鴻蒙HarmonyOS應用

2013-07-15 16:55:45

2011-06-14 12:56:55

SQL Server復災

2024-04-07 08:23:01

JS隔離JavaScript
點贊
收藏

51CTO技術棧公眾號

国产不卡人人| 乱子伦一区二区三区| 日韩一区二区三区精品视频第3页| √…a在线天堂一区| 成人毛片网站| 伊人久久久久久久久久久久| 99久精品视频在线观看视频| 精品免费一区二区三区| 成人一区二区三| 亚洲综合图区| 免费一级欧美在线大片| 一区二区三区精品| 免费看国产精品一二区视频| 深夜福利影院在线观看| 欧美黑人巨大videos精品| 欧美吻胸吃奶大尺度电影| 4444亚洲人成无码网在线观看| 中文字幕乱码人妻无码久久| 欧美日韩午夜| 中文字幕精品一区久久久久| 亚洲成a人无码| 高清在线一区| 欧美网站在线观看| 黄色成人在线免费观看| 午夜看片在线免费| 久久亚洲欧美国产精品乐播| 国产精品自在线| 欧美一级视频免费观看| 欧美二区视频| 中文字幕久久久av一区| 免费看毛片的网站| 视频精品一区| 欧美剧情电影在线观看完整版免费励志电影| 国产精品裸体瑜伽视频| free性欧美hd另类精品| 国产精品的网站| 日韩影院一区| 精品无人乱码| 久久蜜桃av一区精品变态类天堂 | 久草视频精品在线| 99精品在线观看| 色小说视频一区| 永久免费成人代码| 羞羞色国产精品网站| 亚洲精品在线免费播放| 熟妇无码乱子成人精品| 图片一区二区| 国产精品久久久爽爽爽麻豆色哟哟| 国内精品二区| 人人妻人人玩人人澡人人爽| 国产精品66部| 久久免费视频在线| 日韩黄色免费观看| 91精品蜜臀一区二区三区在线| 91麻豆精品国产91久久久资源速度 | 国产这里只有精品| 亚洲综合成人av| 成人婷婷网色偷偷亚洲男人的天堂| 亚洲成人av在线| 久草免费资源站| 国产精品中文字幕制服诱惑| 欧美精品一区二区久久久| 无码人妻精品一区二区三| 伊人久久大香线蕉av超碰| 日韩久久久久久| 国产又黄又嫩又滑又白| jizz国产精品| 亚洲国产又黄又爽女人高潮的| 青青草视频网站| 欧美综合精品| 一本一本久久a久久精品综合小说 一本一本久久a久久精品牛牛影视 | 一本加勒比波多野结衣| 天海翼精品一区二区三区| 日韩精品在线观看网站| 久久久久久久毛片| 91一区在线| 欧美乱大交xxxxx| 日本特黄一级片| 亚洲女人av| 国产精品视频精品视频| 国产露脸91国语对白| 成人一区二区视频| 天天综合天天综合色| 国产在线黄色| 亚洲最大综合网| 欧美二区在线看| 黑人玩弄人妻一区二区三区| 久久伊人影院| 亚洲第一网站男人都懂| 香蕉视频黄色在线观看| 成人免费a**址| 久久亚洲精品一区| 日本熟女一区二区| 日韩精品成人一区二区三区| 成人免费淫片aa视频免费| 亚洲男人天堂久久| 国产午夜精品理论片a级大结局 | 亚洲精品18在线观看| 中文字幕在线观看91| 国产在线精彩视频| 色94色欧美sute亚洲线路二| 欧美激情第3页| 国模精品视频| 欧美性三三影院| 又色又爽又黄18网站| 99久久er| 精品久久久久久最新网址| 国产成人精品无码免费看夜聊软件| 天天综合国产| 欧美一级大胆视频| 精品国产无码AV| 国产农村妇女毛片精品久久麻豆| 精品视频在线观看一区二区| 欧美日韩尤物久久| 日韩欧美成人午夜| 蜜桃av免费在线观看| 亚洲精品美女91| 成人性生交xxxxx网站| 日色在线视频| 亚洲国产一二三| 久久久久久久久久久久久国产| caoporn视频在线| 9191国产精品| jizz中文字幕| 亚洲一区二区三区高清| 99久久无色码| 国产一二三区在线观看| 欧美在线三级电影| 亚洲黄色小视频在线观看| 国产伦精品一区二区三区免费优势| 综合av色偷偷网| 国内自拍视频在线播放| 日韩国产欧美在线视频| 精品国产乱码久久久久久蜜柚| 成人免费高清| 欧美日韩成人一区二区| 日韩毛片无码永久免费看| 欧美亚洲专区| 精品视频一区在线| 超碰在线97国产| 黄色一区二区在线观看| jjzz黄色片| 欧美精品播放| 91免费看网站| 在线播放免费av| 欧美一区二区免费| 在线免费播放av| 国产精品v日韩精品v欧美精品网站| 国产欧美日韩91| 97视频精彩视频在线观看| 91黄色免费观看| 国产精品三级在线观看无码| 国产精品一页| 欧美一区二区三区四区夜夜大片| 色老头在线一区二区三区| 日韩影院精彩在线| 国产91精品高潮白浆喷水| 亚洲AV成人无码一二三区在线| 3d欧美精品动漫xxxx无尽| 在线观看三级视频欧美| 国产综合精品在线| 肉色丝袜一区二区| 亚洲国产精品一区二区第一页| 日韩免费小视频| 在线日韩日本国产亚洲| 最近中文字幕av| 国产精品全国免费观看高清| av在线网址导航| 中文字幕乱码亚洲无线精品一区| 91久久精品一区二区别| av资源一区| 亚洲理论在线a中文字幕| 久久久免费高清视频| 久久久久久9999| 一级黄色特级片| 亚洲精品国产偷自在线观看| 99久久自偷自偷国产精品不卡| 91超碰国产在线| 亚洲日韩第一页| 在线视频播放大全| 福利一区二区在线观看| 久久久久久久香蕉| 免费欧美激情| 成人国产在线激情| wwwwxxxx在线观看| 亚洲男人天堂网| 91麻豆国产视频| 99精品视频在线观看| 国产l精品国产亚洲区久久| 精品国产乱码久久久久久果冻传媒| 国产精品久久久久久久久久免费| 黄色精品在线观看| 精品视频在线播放色网色视频| 精品乱码一区内射人妻无码| 亚洲人成网站影音先锋播放| 中文字幕在线播放视频| 免费精品视频最新在线| 免费在线国产精品| 高清一区二区中文字幕| 午夜精品在线观看| 欧美激情黑人| 日韩第一页在线| 国产又粗又猛又爽| 欧美视频在线观看 亚洲欧| 992在线观看| 91影院在线观看| 中文字幕avav| 日韩国产在线观看一区| 成人免费性视频| 福利视频亚洲| 韩剧1988免费观看全集| 青青青青在线| 亚洲欧美在线播放| 亚洲av无码片一区二区三区 | 日韩一区二区三区免费| 久久人人爽人人爽爽久久| 日本免费一区二区三区最新| 日韩欧美在线网站| 中文字幕久久网| 欧美日韩国产精品专区| 欧美黄色免费观看| 中文字幕一区在线观看视频| www.中文字幕av| 成人综合在线观看| 日韩欧美中文视频| 男女男精品视频网| 黄色高清无遮挡| 国产日韩欧美一区在线 | 天堂成人国产精品一区| 阿v天堂2018| 欧美日韩第一区| 欧美爱爱视频网站| 成人亚洲一区| 麻豆av一区| 日韩精品社区| 国偷自产av一区二区三区小尤奈| www.成人在线.com| 久久中文字幕一区| 91在线不卡| 亚洲天堂男人天堂| 一区二区视频网| 色婷婷精品大视频在线蜜桃视频| 久久夜色精品亚洲| 亚洲午夜三级在线| 久久网中文字幕| 亚洲欧美日韩久久精品| 亚洲综合久久av一区二区三区| 国产三级精品视频| 国产一级久久久久毛片精品| 国产亚洲欧美日韩俺去了| 免费看黄色aaaaaa 片| 波多野结衣在线一区| 韩国三级hd两男一女| 成人免费看的视频| www.超碰97| 久久伊99综合婷婷久久伊| 免费看黄色aaaaaa 片| 2023国产精品| 最新中文字幕av| 国产精品久久久久久久久久久免费看 | 久久视频精品在线| 国产成人高清精品| 欧美成人午夜免费视在线看片 | 色综合综合网| 翔田千里亚洲一二三区| 欧美xxav| 亚洲小视频在线播放| 在线欧美亚洲| 日本视频一区二区在线观看| av中文字幕一区二区| 亚洲国产激情一区二区三区| 99久久精品国产亚洲精品| 最近免费观看高清韩国日本大全| 欧美日韩综合| 精品无码一区二区三区在线| 久热国产精品| 亚洲视频一二三四| 懂色中文一区二区在线播放| 日本japanese极品少妇| 国产日韩欧美在线一区| 四虎永久免费在线| 国产日韩高清在线| 免费在线观看黄色小视频| 亚洲一区二区三区四区不卡| 97免费在线观看视频| 在线观看国产一区二区| 国产aⅴ爽av久久久久成人| 亚洲国产精品一区二区三区| 国产永久免费高清在线观看| 久久av资源网站| 亚洲永久av| 亚洲综合日韩在线| 精品在线99| 久久视频免费在线| 免费看亚洲片| 在线观看免费看片| 久久久蜜桃精品| 在线看的片片片免费| 欧美小视频在线观看| 国产精品视频第一页| 亚洲黄页视频免费观看| 蜜桃视频在线观看免费视频网站www| 久久久久久久久久久亚洲| 精品日韩视频| 精品不卡在线| 伊人成综合网| 无码人妻精品一区二区三区66| 国产成人一区二区精品非洲| 制服 丝袜 综合 日韩 欧美| 亚洲一区二区三区四区五区中文| 成人黄色片在线观看| 精品99999| 国产在线观看91| 日韩av免费看| 任你弄精品视频免费观看| 国产又黄又爽免费视频| 日本伊人色综合网| 制服丝袜第一页在线观看| 亚洲美女淫视频| 在线免费观看一区二区| 亚洲人成网站777色婷婷| 欧美精品videosex| 久久久久久久激情视频| 久久精品xxxxx| 成人在线激情视频| 国产va免费精品观看精品视频| 久久这里只有精品23| 国产一区视频在线看| 国产av自拍一区| 疯狂蹂躏欧美一区二区精品| 国产黄色片av| 欧美成人第一页| 国产 日韩 欧美| 亚洲视频sss| 欧美色一级片| 亚洲涩涩在线观看| 国产欧美日韩在线| 免费看一级视频| 日韩精品免费电影| 日本在线影院| 精品国产乱码久久久久久108| 亚洲特色特黄| 成人啪啪18免费游戏链接| 亚洲三级在线看| 97免费观看视频| 久久成人精品电影| 国产精品99久久免费| 97超碰免费观看| 精品写真视频在线观看 | 日韩综合网站| 在线观看免费视频高清游戏推荐| 国产欧美日韩激情| 69av视频在线观看| 在线观看国产成人av片| a屁视频一区二区三区四区| 亚洲成人av动漫| 九色porny丨国产精品| 精品国产欧美日韩不卡在线观看| 欧美一级久久久| 欧美xxxx免费虐| 激情欧美一区二区三区中文字幕| 一二三区精品| 一级黄色性视频| 欧美日韩卡一卡二| 免费av网站在线看| www日韩av| 国产农村妇女毛片精品久久莱园子| 欧美熟妇一区二区| 欧美少妇bbb| 污污的视频在线观看| 国产一区福利视频| 欧美一级视频| 国精产品视频一二二区| 欧美一级免费大片| 天堂电影一区| 中文字幕中文字幕99| 国产成人精品免费在线| 国产成人精品一区二三区| 亚洲欧美中文日韩在线v日本| www.国产精品| 男女激烈动态图| 91丨九色丨国产丨porny| 在线免费av片| 久久久久久成人| 国产一区二区三区四区大秀| 精品综合久久久久| 黄色精品一区二区| 思思99re6国产在线播放| 98国产高清一区| 日本网站在线观看一区二区三区| 99久久99久久精品国产| 日韩av在线免费| 香蕉成人在线| 91视频最新入口| 成人小视频在线| 亚洲国产成人精品女人久久| 欧美精品一二区| 欧美日韩伦理| av电影在线播放| 欧美精品777|