extends

在 TypeScript 中,extends 关键字用于接口继承,表示一个接口可以继承另一个接口的属性和方法。

📌 代码解析

typescript

复制代码
interface FlatTableData extends buildingManagementListType {
  _floorId: string;
  _unitIndex: number;
  _floorUnitCount: number;
}

这行代码的意思是:

  • FlatTableData 接口继承了 buildingManagementListType 接口的所有属性

  • 同时添加了三个新的属性_floorId_unitIndex_floorUnitCount

🔍 三种理解方式

1. 集合论角度(最直观)

typescript

复制代码
// 可以理解为属性的并集
type FlatTableData = buildingManagementListType & {
  _floorId: string;
  _unitIndex: number;
  _floorUnitCount: number;
}
2. 面向对象角度

typescript

复制代码
// 类似于类的继承
class buildingManagementListType {
  buildingId: string;
  buildingName: string;
  // ...
}

class FlatTableData extends buildingManagementListType {
  _floorId: string;
  _unitIndex: number;
  _floorUnitCount: number;
}

🎨 多层继承

typescript

复制代码
// 可以有多层继承
interface BaseBuilding {
  buildingId: string;
}

interface buildingManagementListType extends BaseBuilding {
  buildingName: string;
  address: string;
}

interface FlatTableData extends buildingManagementListType {
  _floorId: string;
  _unitIndex: number;
  _floorUnitCount: number;
}

⚠️ 注意事项

1. 不能覆盖(重写)属性类型
2. 可选属性的继承
3. 多个接口继承

📝 总结

extends 在 TypeScript 接口中的含义:

  1. 继承:子接口获得父接口的所有属性

  2. 扩展:可以在继承的基础上添加新属性

  3. 兼容:子接口类型的对象可以赋值给父接口类型

  4. 约束:父接口的属性类型约束也会被子接口继承

相关推荐
NE_STOP12 小时前
Docker--Docker Swarm集群
java
2301_7736436212 小时前
ceph池
开发语言·ceph·python
两年半的个人练习生^_^12 小时前
JMM 进阶:彻底理解 CAS 实现原理
java·开发语言
wuminyu12 小时前
Java锁机制之park和unpark源码剖析
java·linux·c语言·jvm·c++
半个烧饼不加肉13 小时前
JS 底层探究-- 事件循环
开发语言·前端·javascript
W_LuYi18513 小时前
手撸极简zkEVM验证器:RISC-V电路实践
java·risc-v
asdfg125896313 小时前
C 语言中产生伪随机数的标准做法
c语言·开发语言
AI人工智能+电脑小能手13 小时前
【大白话说Java面试题 第102题】【并发篇】第2题:volatile 能否保证线程安全?
java·安全·面试
KobeSacre13 小时前
JUC 概述
java·开发语言
小bo波14 小时前
形式化方法 × UML
java·软件工程·uml·面向对象·形式化方法·tla+