当前位置:网站首页>typescript type 和 interface 的区别

typescript type 和 interface 的区别

2022-08-04 03:04:00 alokka

1. interface侧重于描述数据结构,type侧重于描述类型

interface A{
     name:string; } 
type B = 'bb'|'cc' 

2. 都可以描述一个对象或者函数

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

type hoster = {
    
  name: string;
  age: number;
}
type setHoster = (name: string, age: number) => void

3. interface 可以定义相同的类型名称,多个相同类型名称会合并,type 不可以

interface Window {
    
  title: string
}

interface Window {
    
  ts: TypeScriptAPI
}

const src = 'const a = "Hello World"';
window.ts.transpileModule(src, {
    });
type Window = {
    
  title: string
}

type Window = {
    
  ts: TypeScriptAPI
}

 // Error: Duplicate identifier 'Window'.

4. interface 可以继承, type不可以


interface Animal {
    
  name: string
}

interface Bear extends Animal {
    
  honey: boolean
}

const bear = getBear() 
bear.name
bear.honey
type Animal = {
    
  name: string
}

type Bear = Animal & {
     
  honey: boolean 
}

const bear = getBear();
bear.name;
bear.honey;

5. type专属功能

// type专属 联合类型

interface Dog {
    
  wang()
}
interface Cat {
    
  miao()
}
type Pet = Dog | Cat
type PetList = [Dog,Cat]
原网站

版权声明
本文为[alokka]所创,转载请带上原文链接,感谢
https://blog.csdn.net/alokka/article/details/126092624