TS 中 interface 和 type 详解

news2025/4/2 19:18:49

在 TypeScript 中,interfacetype 都可以用来定义类型,但它们有一些关键的区别。以下是它们的详细对比:


1. 基本定义

  • interface
    用于声明对象的形状(属性和方法),是面向对象编程中“接口”概念的体现。

    interface Person {
      name: string;
      age: number;
      greet(): void;
    }
    
  • type
    用于定义类型的别名,可以表示任何类型(包括对象、联合类型、交叉类型、元组等)。

    type Person = {
      name: string;
      age: number;
      greet(): void;
    };
    
    type ID = string | number; // 联合类型
    type Coordinates = [number, number]; // 元组
    

2. 扩展性

  • interface
    通过 extends 直接扩展其他接口,支持声明合并(多次声明同名接口会自动合并)。

    interface Animal {
      name: string;
    }
    
    interface Dog extends Animal {
      bark(): void;
    }
    
    // 声明合并
    interface User {
      id: string;
    }
    
    interface User {
      name: string;
    }
    
    // 最终 User 类型为 { id: string; name: string }
    
  • type
    通过 & 实现交叉类型来扩展,但无法直接扩展其他类型别名。

    type Animal = {
      name: string;
    };
    
    type Dog = Animal & {
      bark(): void;
    };
    
    // 无法合并同名类型别名
    type User = { id: string };
    type User = { name: string }; // ❌ 报错
    

3. 灵活性

  • interface
    仅能定义对象类型,无法直接表示联合类型、交叉类型或基本类型别名。

    interface A = string; // ❌ 报错
    
  • type
    可以表示任意复杂类型:

    type StringOrNumber = string | number; // 联合类型
    type Point3D = { x: number } & { y: number } & { z: number }; // 交叉类型
    type Callback = (data: string) => void; // 函数类型
    type Pair<T> = [T, T]; // 泛型元组
    

4. 实现(implements

  • interface
    类可以直接通过 implements 实现接口:

    interface Animal {
      name: string;
      eat(): void;
    }
    
    class Dog implements Animal {
      name = "Buddy";
      eat() { console.log("Eating..."); }
    }
    
  • type
    类型别名也可以被类实现,但语法需要严格匹配:

    type Animal = {
      name: string;
      eat(): void;
    };
    
    class Dog implements Animal {
      name = "Buddy";
      eat() { console.log("Eating..."); }
    }
    

5. 工具类型兼容性

  • interface
    某些工具类型(如 OmitPick)可能对接口更友好:

    interface User {
      id: string;
      name: string;
      age: number;
    }
    
    type SimpleUser = Omit<User, "age">; // { id: string; name: string }
    
  • type
    类型别名与工具类型完全兼容,但可能需要额外操作:

    type User = {
      id: string;
      name: string;
      age: number;
    };
    
    type SimpleUser = Omit<User, "age">;
    

6. 性能差异

  • interface
    在大型项目中,接口的声明合并特性可能导致意外的类型扩展,需谨慎使用。
  • type
    类型别名在复杂类型操作(如递归)中可能更高效,但实际差异通常可以忽略。

7. 使用场景建议

场景推荐使用原因
定义对象类型interface支持声明合并、扩展更直观
需要联合或交叉类型type无法用 interface 直接表示
类实现(implementsinterface更符合面向对象设计
需要类型别名(如元组)typeinterface 无法定义非对象类型
第三方库类型扩展interface通过声明合并扩展类型

总结

特性interfacetype
声明方式声明对象形状定义类型别名
扩展extends 或声明合并& 交叉类型
灵活性仅对象类型任意类型(联合、交叉、元组等)
合并声明✅ 支持❌ 不支持
实现类implements✅ 需要严格匹配
工具类型兼容性

最佳实践

  1. 优先使用 interface
    当需要定义对象类型或需要扩展性时(尤其是库的类型定义)。
  2. 使用 type 的场景
    需要联合类型、交叉类型、元组或复杂类型操作时。
  3. 避免混合使用
    在项目中保持一致性,避免同时用 interfacetype 定义同一类型。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2325863.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

文法 2025/3/3

文法的定义 一个文法G是一个四元组&#xff1a;G(,,S,P) &#xff1a;一个非空有限的终极符号集合。它的每个元素称为终极符号或终极符&#xff0c;一般用小写字母表示。终极符号是一个语言不可再分的基本符号。 &#xff1a;一个非空有限的非终极符号集合。它的每个元素称为…

蚂蚁集团主导的ISO密码学国际标准立项,纳入国产算法

蚂蚁集团主导的ISO密码学国际标准 ISO 25330-3 立项&#xff0c; 国产算法Ferret成为标准方案。 近日&#xff0c;在美国弗吉尼亚州举行的 ISO/IEC JTC 1/SC 27 全体会议上&#xff0c;ISO/IEC 25330第三部分《Information Security — Oblivious Transfer — Part 3: Obliv…

nginx的用户认证

[rootserver100 html]# htpasswd -cm /usr/local/nginx/.htpasswd lee 创建用户给密码 编写nginx的配置文件 [rootserver100 html]# echo lee > /data/web/lee/index.html 写入实验内容 访问成功 用户访问认证的设定 用户认证的设定成功

为什么要指针压缩,为什么能指针压缩?原理是什么?

指针压缩&#xff08;Compressed Oops&#xff09;的原理与实现 指针压缩是 JVM 在 64 位环境 下优化内存占用的关键技术&#xff0c;通过减少对象指针的内存开销&#xff0c;提升缓存利用率和性能。以下是其核心原理与设计细节&#xff1a; 一、为什么要指针压缩&#xff1f;…

使用DeepSeek API进行情感分析:超简单

文章目录 1. 引言1.1 情感分析概述1.2 为什么选择DeepSeek API1.3 本文目标 2. 技术方案对比2.1 传统情感分析方法2.2 基于LLM的方法DeepSeek API优势 3. DeepSeek 情感分析实战3.1 Few-shot Learning方法3.2 完整的DeepSeek API调用示例3.3 案例演示 4. DeepSeek开发情感分析工…

一套SaaS多租户医疗云his源码,基于云计算的医院信息管理系统(云HIS)

基于云计算的医院信息管理系统&#xff08;云HIS&#xff09;&#xff0c;通过SaaS服务模式提供。这种云HIS系统设计考虑了模板化、配置化、智能化和可扩展性&#xff0c;覆盖了基层医疗机构的核心工作流程&#xff0c;并且能够与监管系统无缝对接&#xff0c;满足未来的扩展需…

数据处理与机器学习入门

一、数据处理概述 数据处理是通过统计学、机器学习和数据挖掘方法从原始数据中提取有价值信息的过程。数据处理的目标是将杂乱无章的原始数据转化为可用于分析和建模的结构化数据。对于小规模数据处理&#xff0c;常用工具分为两类&#xff1a; • 可视化分析工具&#xff1a…

【SPP】深入解析蓝牙 L2CAP 协议在SPP中的互操作性要求 —— 构建可靠的蓝牙串口通信基础

在蓝牙协议体系中&#xff0c;L2CAP&#xff08;Logical Link Control and Adaptation Protocol&#xff09;作为基带协议与高层协议之间的桥梁&#xff0c;承担着数据分帧、协议复用、QoS协商等核心功能。当涉及串行端口通信时&#xff0c;L2CAP的规范实现直接决定了设备间数据…

21 模板方法(Template Method)模式

模板方法模式 1.1 分类 &#xff08;类&#xff09;行为型 1.2 提出问题 做一款数据挖掘的程序&#xff0c;需要支持不同格式的数据文件&#xff0c;虽然文件格式不同&#xff0c;实现步骤基本一致。 1.3 解决方案 定义一个算法骨架&#xff0c;而将一些步骤延迟到子类。…

一些练习 C 语言的小游戏

一些练习 C 语言的小游戏 — 1. 猜数字游戏 描述&#xff1a;程序随机生成一个数字&#xff0c;玩家需要猜测这个数字&#xff0c;并根据提示&#xff08;太高或太低&#xff09;调整猜测&#xff0c;直到猜中为止。 功能点&#xff1a; 随机数生成 (rand() 函数)。循环和…

【AI News | 20250331】每日AI进展

AI Repos 1、MCP-Chinese-Getting-Started-Guide 模型上下文协议&#xff08;MCP&#xff09;是一个创新的开源协议&#xff0c;旨在标准化大语言模型&#xff08;LLM&#xff09;与外部数据源及工具的连接方式&#xff0c;类似AI应用的“USB-C接口”。其核心功能包括资源、提…

C++/数据结构:哈希表知识点

目录 哈希表 理解哈希表 哈希值&#xff08;整形&#xff09; BKDR哈希 异或组合 hash_combine 哈希函数 直接定址法 除留余数法 平方取中法 基数转换法 哈希冲突 开放定址法 哈希桶 unordered_map和unorder_set如何共用一个哈希桶模板类 stl的哈希桶中Insert如…

基于SpringBoot的求职招聘网站系统(源码+数据库)

473基于SpringBoot的求职招聘网站系统&#xff0c;本系统共分为2个角色&#xff1a;系统管理员、用户&#xff0c;主要功能如下 【前台功能】 用户角色功能&#xff1a; 1. 注册和登录&#xff1a;注册账户并登录系统&#xff0c;以便访问更多功能。 2. 个人信息管理&#x…

Linux : System V 共享内存

目录 一 前言 二 共享内存概念 三 共享内存创建 四 查看共享内存 五 共享内存的删除 六 共享内存的关联 七 共享内存去关联 八 共享内存的使用&#xff08;通信&#xff09; 九 共享内存的特点 一 前言 共享内存区是最快的IPC形式&#xff08;进程间通信&#xff1…

端到端语音识别案例

《DeepSeek大模型高性能核心技术与多模态融合开发&#xff08;人工智能技术丛书&#xff09;》(王晓华)【摘要 书评 试读】- 京东图书 语音识别这一技术正如其名&#xff0c;是通过精密地解析说话人的语音来识别并准确转写出其所说的内容。它不仅仅是一个简单的转录过程&#…

【软件系统架构】微服务架构

一、引言 随着互联网技术的快速发展&#xff0c;传统的单体应用架构在面对复杂业务需求时逐渐暴露出诸多问题&#xff0c;如开发效率低、部署困难、扩展性差等。为了解决这些问题&#xff0c;微服务架构应运而生。本文将详细介绍微服务架构的定义、发展历史、特点、细分类型、优…

Linux内核设计——(一)进程管理

目录 一、进程及线程简介 二、进程描述符 2.1 进程描述符简介 2.2 分配进程描述符 2.3 进程标识值 2.4 进程状态 2.5 进程上下文 三、进程创建 3.1 写时拷贝 3.2 fork()和vfork() 四、线程 4.1 Linux线程实现 4.2 内核线程 五、进程终结 5.1 删除进程描述符 5.…

22 安装第三方包

一、什么是第三方包 在 Python 的世界里&#xff0c;包就像是一个个功能强大的工具箱&#xff0c;它将多个 Python 模块收纳其中&#xff0c;而每个模块又蕴含着丰富多样的具体功能。可以说&#xff0c;一个包就是一系列同类功能的集合体&#xff0c;它们就像紧密协作的团队&a…

oracle 常用函数的应用

在使用开发中会经常遇到数据类型转换、显示系统时间等情况&#xff0c;需要使用函数来实现。通过函数来实现业务需求会非常的省事便捷&#xff0c;函数可以用在适当的dml语句和查询语句中。 Oracle 数据库中主要使用两种类型的函数&#xff1a; (1)单行函数&#xff1a;对每一个…

“上云入端” 浪潮云剑指组织智能化落地“最后一公里”

进入2025年&#xff0c;行业智能体正在成为数实融合的核心路径。2025年初DeepSeek开源大模型的横空出世&#xff0c;通过算法优化与架构创新&#xff0c;显著降低算力需求与部署成本&#xff0c;推动大模型向端侧和边缘侧延伸。其开源策略打破技术垄断&#xff0c;结合边缘计算…