解讀Typescript中interface和type的用法及區(qū)別
更新時間:2025年02月05日 09:01:12 作者:¢C-TiAmo
在TypeScript中,`interface`和`type`都可以用來定義自定義類型,但它們在語法、聲明合并、可擴展性、兼容性、類型注解和類型別名、訪問修飾符、聯(lián)合類型與交叉類型、實現(xiàn)接口和類型別名、映射類型、泛型參數(shù)位置、擴展對象類型以及調(diào)用簽名和構(gòu)造函數(shù)等方面存在一些差異
Typescript中interface和type區(qū)別
在typeScript中,“interface”和“type”都是用來定義自定義類型的關鍵字,他們在以下差異,用法上的一些區(qū)別(歡迎大家繼續(xù)補充……)
1. 語法差異
- 'interface’使用關鍵字’interface’定義,例如:interface Person { name: string; }
- 'type’使用關鍵字’type’定義,例如:type Person = { name: string; }
2.聲明合并(Merging)的能力
- 'interface’具有聲明合并的能力,允許多個同名的接口進行合并,通過這樣的方式可以擴展接口的成員定義。
- 'type’不具備聲明合并的能力,多次定義同一個類型會報錯
3.可擴展性
- 'interface’可以使用關鍵字’extends’繼承另一個接口,實現(xiàn)接口的復用和擴展。
- 'type’可以使用交叉類型(Intersection Types)進行復用和擴展,但不能使用extends關鍵字繼承。
4.兼容性
- 'interface’在進行類型兼容性檢查時,會進行"兼容性遞歸檢查",只要目標類型滿足源類型的成員要求,就認為類型兼容。
- 'type’沒有進行"兼容性遞歸檢查",只有精確匹配才被認為是兼容。
5.類型注解和類型別名
- 'interface’可以用于定義函數(shù)類型、類類型等復雜類型的注解。
- 'type’可以用于定義任意類型的別名,可以簡化復雜類型的書寫。
6.訪問修飾符
- 'interface’可以在屬性和方法上使用公共(public),私有(private)和受保護(protected)等訪問修飾符。
- 'type’不能指定訪問修飾符,它假定所有成員都是公共的。
7.聯(lián)合類型與交叉類型
- 'type’可以使用聯(lián)合類型(Union Types)和交叉類型(Intersection Types)來組合多個類型。
- 'interface’沒有直接支持聯(lián)合類型和交叉類型的語法,但可以通過繼承和聲明合并的方式實現(xiàn)類似的效果。
8.實現(xiàn)接口和類型別名
- 'interface’可以被類實現(xiàn)(implements)來強制約束類的結(jié)構(gòu)。
- 'type’不能直接被類實現(xiàn),它更適合作為類型別名來簡化復雜類型的定義。
9.映射類型
- 'type’可以使用映射類型來根據(jù)已有類型生成新的類型。
- 'interface’不支持映射類型。
type Options<T> = { [K in keyof T]: boolean; }; interface PersonOptions { name: boolean; age: boolean; } // 使用映射類型 type Result = Options<PersonOptions>; // Result 的類型為 { name: boolean, age: boolean } // 不能使用映射類型 // interface ResultInterface extends Options<PersonOptions> {}
10.范型參數(shù)位置
- 在范型參數(shù)位置上,'type’可以出現(xiàn)在任意位置,且可以交叉和聯(lián)合多個類型。
- 在范型參數(shù)位置上,'interface’只能出現(xiàn)在類型別名的右側(cè)。
type Tuple = [number, string]; type NumberArray = Array<number>; type Union = number | string; // 有效的定義 type MyType<T> = { value: T }; type MyType2 = MyType<number>; // 有效的定義 interface MyInterface<T> { value: T; } type MyInterface2 = MyInterface<number>; // 無效的定義 // interface MyInterface<T> { // value: T; // } // interface MyInterface2 extends MyInterface<number> {}
11.擴展對象類型
- 'interface’可以通過聲明合并的方式擴展已有的對象類型,從而添加新的屬性或方法。
- 'type’需要使用交叉類型來實現(xiàn)對象類型的擴展。
interface Person { name: string; } interface ExtendedPerson extends Person { age: number; } // 使用聲明合并進行擴展 const person: ExtendedPerson = { name: 'John', age: 25, }; type Person = { name: string; }; type ExtendedPerson = Person & { age: number; }; // 使用交叉類型進行擴展 const person: ExtendedPerson = { name: 'John', age: 25, };
12.調(diào)用簽名和構(gòu)造函數(shù)
- 'interface’可以定義調(diào)用簽名來描述函數(shù)類型,也可以定義構(gòu)造函數(shù)簽名來描述類的構(gòu)造函數(shù)。
- 'type’可以使用函數(shù)類型和構(gòu)造函數(shù)類型別名來描述函數(shù)類型和類的構(gòu)造函數(shù)。
interface Greeting { (name: string): string; } interface Person { new (name: string): Person; name: string; sayHello(): void; } // 定義調(diào)用簽名和構(gòu)造函數(shù)簽名 const greeting: Greeting = (name) => `Hello, ${name}!`; class PersonClass implements Person { constructor(public name: string) {} sayHello() { console.log(`Hello, my name is ${this.name}.`); } } type Greeting = (name: string) => string; type Person = { new (name: string): Person; name: string; sayHello(): void; }; // 使用類型別名 const greeting: Greeting = (name) => `Hello, ${name}!`; class PersonClass implements Person { constructor(public name: string) {} sayHello() { console.log(`Hello, my name is ${this.name}.`); } }
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
JavaScript.The.Good.Parts閱讀筆記(二)作用域&閉包&減緩全局空間污染
塊級作用域: 大多數(shù)使用c語言語法的語言都有塊級作用域,而JavaScript沒有塊級作用域。2010-11-11layui問題之自動滾動二級iframe頁面到指定位置的方法
今天小編就為大家分享一篇layui問題之自動滾動二級iframe頁面到指定位置的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09JS獲取數(shù)組中出現(xiàn)次數(shù)最多及第二多元素的方法
這篇文章主要介紹了JS獲取數(shù)組中出現(xiàn)次數(shù)最多及第二多元素的方法,涉及javascript針對數(shù)組的遍歷、排序、判斷、查詢等相關操作技巧,需要的朋友可以參考下2017-10-10JS 插件dropload下拉刷新、上拉加載使用小結(jié)
這篇文章主要介紹了JS 插件dropload下拉刷新、上拉加載使用小結(jié),需要的朋友可以參考下2017-04-04GitHub上77.9K的Axios項目有哪些值得借鑒的地方詳析
提到axios,相信大家應該都不會陌生,這篇文章主要給大家介紹了關于GitHub上77.9K的Axios項目有哪些值得借鑒的地方,需要的朋友可以參考下2021-06-06layui實現(xiàn)多圖片上傳并限制上傳的圖片數(shù)量
今天小編就為大家分享一篇layui實現(xiàn)多圖片上傳并限制上傳的圖片數(shù)量,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09