如果你有写过 Vue3 的项目,那么对 TypeScript 肯定不会陌生。不管是公司新项目技术选型还是个人学习开发新的前端项目,Vue3 + TypeScript 已经成为首选技术方案之一

在 TypeScript 这个强大的静态类型系统中,type 和 interface 是两个重要的关键字,用于定义和描述数据类型。然而,这两者之间的区别是什么,在实际开发过程中我们要怎么用呢?废话不说,直接进入正题,就让我们一起深入探讨吧

一、type 和 interface 的定义

  • type: 可以定义一个集合,可以包含各种类型的属性和值,以用来描述对象、函数、联合类型、交叉类型等
type Person = {
name: string;
age: number;
sex: 0 | 1;
};
  • interface:它定义了一个对象的形状,描述了对象应该具有的属性及其类型
interface Person {
name: string;
age: number;
sex: 0 | 1;
}

通过上面的示例,我们可以看到,虽然type 和interface都可以用来描述对象的结构,但是它们的语法略有不同。type 使用等号来定义类型别名,而 interface 使用花括号直接定义接口的成员

二、type 和 interface 的可扩展性

  • type:它可以通过联合类型(|)和交叉类型(&)进行组合,但不能直接扩展其他 type
type A = { x: string };
type B = { y: string };
type C = A & B; // C 同时具有 A 和 B 的属性
  • interface:它可以被扩展,可以使用 extends 关键字来实现接口的继承,从而添加更多属性或者方法
interface Fruit {
name: string;
} interface Apple extends Fruit {
kind: string;
}

综合例子来看,type 适合于定义复杂的类型别名和泛型类型,以及进行条件类型的定义。interface 也具有相似的能力,它适合于描述对象的形状,定义类的契约和实现,以及接口之间的继承和扩展。这两者在许多情况下可以互相替代

三、type 和 interface 的兼容性

  • type:如果对类型别名进行重复定义,TypeScript 会报错。这意味着不能重新定义一个已存在的type
type A = { x: string };
type A = { y: string }; // 错误: 重复定义
  • interface:如果定义了多个同名的接口,它们会被合并成一个单一的接口,而不是报错。当多个同名接口出现时,它们的成员会被合并为一个接口,这种合并会在类型级别上进行,不会在运行时产生影响
interface A {
x: string;
}
interface A {
y: string;
z: string;
}

就拿这个例子来说,无论你使用哪个interface A,都会引用同一个合并后的接口定义。这样的合并机制使得 TypeScript 中的接口能够更加灵活地进行组织和管理

结语

typeinterface 在 TypeScript 中都是用来定义类型的关键字,它们各有优势和适用场景。了解它们之间的区别和特性,可以更好地利用 TypeScript 的类型系统来提高代码质量和开发效率

在日常开发工作中,我们要遵循团队规范。例如,可以用interface定义一个复杂的对象类型,在组合不同类型时,可以使用 type关键字来定义

TypeScript 中的 type 和 interface:你真的了解它们的不同吗?的更多相关文章

  1. 【区分】Typescript 中 interface 和 type

    在接触 ts 相关代码的过程中,总能看到 interface 和 type 的身影.只记得,曾经遇到 type 时不懂查阅过,记得他们很像,相同的功能用哪一个都可以实现.但最近总看到他们,就想深入的了 ...

  2. TypeScript 中的方法重载

    方法重载(overload)在传统的静态类型语言中是很常见的.JavaScript 作为动态语言, 是没有重载这一说的.一是它的参数没有类型的区分,二是对参数个数也没有检查.虽然语言层面无法自动进行重 ...

  3. 十分钟教你理解TypeScript中的泛型

    转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具.解决方案和服务,赋能开发者.原文出处:https://blog.bitsrc.io/understanding-generics-in-t ...

  4. 探索typescript的必经之路-----接口(interface)

    TypeScript定义接口 熟悉编程语言的同学都知道,接口(interface)的重要性不言而喻. 很多内容都会运用到接口.typescrip中的接口类似于java,同时还增加了更灵活的接口类型,包 ...

  5. TypeScript中的private、protected

    首先我们要清楚 private . protected 现阶段只是javascript中的保留字(Reserved words),而非关键字(Keywords ).因此TypeScript中的纯类型声 ...

  6. typescript 中的 infer 关键字的理解

    infer 这个关键字,整理记录一下,避免后面忘记了.有点难以理解呢. infer infer 是在 typescript 2.8中新增的关键字. infer 可以在 extends 条件类型的字句中 ...

  7. TypeScript 中命名空间与模块的理解?区别?

    一.模块 TypeScript 与ECMAScript 2015 一样,任何包含顶级 import 或者 export 的文件都被当成一个模块 相反地,如果一个文件不带有顶级的import或者expo ...

  8. 5种在TypeScript中使用的类型保护

    摘要:在本文中,回顾了TypeScript中几个最有用的类型保护,并通过几个例子来了解它们的实际应用. 本文分享自华为云社区<如何在TypeScript中使用类型保护>,作者:Ocean2 ...

  9. TypeScript中的怪语法

    TypeScript中的怪语法 如何处理undefined 和 null undefined的含义是:一个变量没有初始化. null的含义是:一个变量的值是空. undefined 和 null 的最 ...

  10. JavaScript 和 TypeScript 中的 class

    对于一个前端开发者来说,很少用到 class ,因为在 JavaScript 中更多的是 函数式 编程,抬手就是一个 function,几乎不见 class 或 new 的踪影.所以 设计模式 也是大 ...

随机推荐

  1. apisix~路由前缀的正则匹配

    参考:https://apisix.apache.org/zh/docs/apisix/FAQ/ 在你提供的 Apache APISIX 路由配置中,vars 字段用于定义一些变量匹配规则.具体来说, ...

  2. 使用canal将数据同步到ROCKETMQ

    概述 我们需要将数据从MYSQL写入到rocketmq.实现步骤如下: 安装canal.admin 修改配置 server: port: 8849 spring: jackson: date-form ...

  3. Python 学习记录 (4)

    Plotly常见可视化方案:以鸢尾花数据为例 简单介绍: Ploty库也有大量统计可视化方案,并且这些可视化方案具有交互化属性. 主要对鸢尾花数据进行处理与可视化. 所展示的结果为交互界面的截图情况, ...

  4. 服务拆分之《阿里云OCR使用指南》

    在做一件什么事情: 遇到了什么问题: 问题分析: 业界解决方案: 我的方案: 最终的结果: 服务都已经迁移过来了,对应的那些使用的工具什么的也都得换成自己的账号.起初原始用的是什么忘记了,时间太长了已 ...

  5. 【Amadeus原创】Docker容器的备份与还原

    主要作用: 就是让配置好的容器,可以得到复用,后面用到得的时候就不需要重新配置. 其中涉及到的命令有: docker commit 将容器保存为镜像 docker save -o 将镜像备份为tar文 ...

  6. Vue2 面试题 (2023-09-22更新)

    基础 Vue2.0 兼容 ie 哪个版本? 不支持 ie8,部分兼容 ie9,完全兼容 ie10 因为 vue 的响应式原理是基于 es5 的 Object.defineProperty 这个方法不支 ...

  7. Linux行号显示

    xshell显示行号: 输入命令: vim ~/.vimrc 输入: set nu 之后在打开文件 就可以 看到行号显示.

  8. .NET周刊【12月第3期 2024-12-15】

    国内文章 重磅推出 Sdcb Chats:一个全新的开源大语言模型前端 https://www.cnblogs.com/sdcb/p/18597030/sdcb-chats-intro Sdcb Ch ...

  9. 操作系统messages文件位置更改

    问题现象 在遇到一个问题的时候需要查看操作系统的日志,但是到操作系统上的 /var/log/messages 文件中发现该文件已经很久没有刷新过了. 这个系统之前是做过安全加固的,我怀疑它改过操作系统 ...

  10. 基于开源IM即时通讯框架MobileIMSDK:RainbowChat-iOS端v9.1版已发布

    关于MobileIMSDK MobileIMSDK 是一套专门为移动端开发的开源IM即时通讯框架,超轻量级.高度提炼,一套API优雅支持 UDP .TCP .WebSocket 三种协议,支持 iOS ...