typescript中interface和type的区别

在TypeScript中,interface和type都用于定义类型,但它们有以下区别:

  1. 语法
    interface使用关键字interface来定义类型,而type使用关键字type来定义类型。
  2. 定义方式
    • interface 可以通过继承其他interface来扩展自身的属性和方法,也可以多次声明同名的interface,它们会自动合并成一个接口。
    • type可以使用交叉类型(用&连接)或联合类型(用 | 连接)来组合其他类型,但不能直接继承其他type。同样的,多次声明同名的type导致类型冲突错误。
javascript 复制代码
interface Person {
	name: string
}

interface Employee extends Person {
	salary: number;
}

const john: Person = { name: 'John' };

type Dog = {
	name: string;
}

type GuardDog = Dog & {
	isGurading: boolean;
}

const dog: GuardDog = { name: "Buddy", isGuarding: true}
  1. 同名合并
    • 如果你定义了多个同名的interface,它们会被自动合并成一个,合并后的interface会拥有所有定义的属性和方法。
    • type不支持同名合并,如果多次声明同名的type,则会导致类型冲突错误。
javascript 复制代码
interface Person {
	name: string;
}
interface Person{
	age: number;
}

const p: Person = { name: 'John', age: 25 };
  1. 兼容性
    • 对于对象类型,interface会进行兼容性检查以确保属性的兼容性和缺失属性的检查;而type则更加宽松,只要目标类型具有所需的属性即可。
    • 当使用implement关键字实现一个接口时,编译器会强制检查是否实现了所有接口的属性和方法。
javascript 复制代码
interface Animal {
	name: string;
}

type Dog = {
	name: string;
	breed: string;
}

const animal: Animal = { name: 'Tom' };
const dog: Dog = { name: 'Spike', breed: "Labrador"};

animal = dog; // 兼容
dog = animal; // 不兼容

总体来说,interface主要用于定义对象类型和接口的继承,而type则更灵活,可以定义复杂的类型别名。在选择使用interface还是type时,可以根据具体情况和个人偏好来决定。一般情况下,如果需要定义对象的结构或者实现类似接口的功能,可以使用interface;如果需要描述更复杂的类型或进行类型组合,可以使用type。

相关推荐
FlyWIHTSKY1 分钟前
Vue 3 onMounted 中控制同步与异步执行策略
前端·javascript·vue.js
蜗牛攻城狮6 分钟前
【Vue3实战】El-Table实现“超过3行省略,悬停显示全文”的完美方案(附性能优化)
前端·vue.js·性能优化·element-plus
孙12~6 分钟前
前端vue3+vite,后端SpringBoot+MySQL
前端·html·学习方法
隔壁小邓8 分钟前
vue的组件化的理解之单独拆分的组件&组件的封装
前端·javascript·vue.js
Ivanqhz9 分钟前
图着色寄存器分配算法(Graph Coloring)
开发语言·javascript·python·算法·蓝桥杯·rust
困惑阿三9 分钟前
全栈部署排雷手册:从 405 报错到飞书推送成功
服务器·前端·后端·nginx·阿里云·node.js·飞书
无名-CODING10 分钟前
从零开始!Vue3+SpringBoot前后端分离项目Docker部署实战(下):Vue前端Nginx反代与致命坑点盘点
前端·spring boot·docker
我命由我1234510 分钟前
Element Plus 问题:选择框表单校验没有触发
开发语言·前端·javascript·html·ecmascript·html5·js
optimistic_chen20 分钟前
【Vue3入门】vue-router 路由管理
前端·javascript·vue.js·路由·router
牧码岛30 分钟前
服务端之NestJS请求解析体系、从HTTP报文到参数注入的工程化实践、控制器方法、装饰器、Headers、Query、Param、Body、Req
typescript·nestjs