TypeScript 基础学习笔记:interface 与 type 的异同

news2025/1/16 0:50:06

在这里插入图片描述

🔥 个人主页:空白诗

在这里插入图片描述

文章目录

  • TypeScript 学习笔记:`interface` 与 `type` 的异同
    • 🎣 引言
    • 🚀 快速入门
      • 1️⃣ Interface(接口)
        • 📋 定义
        • 🤝 实现
        • 💡 特点
      • 2️⃣ Type Aliases(类型别名)
        • 📜 定义
        • 🎯 应用
        • 🧠 特点
    • 📊 `interface` 与 `type` 的区别
    • 🌟 实践建议
    • 🚀 总结

在这里插入图片描述


TypeScript 学习笔记:interfacetype 的异同

🎣 引言

TypeScript的世界里,精准的类型定义是保证代码质量与团队协作效率的关键。interfacetype 作为两种核心的类型定义工具,它们各自承载着不同的设计意图与应用场景。本文旨在清晰阐述两者的基本概念、应用场景及核心差异,帮助开发者在实际编码过程中做出更为合适的选择,进一步提升代码的健壮性和可维护性。

🚀 快速入门

TypeScript 中,类型系统是为了增强 JavaScript类型安全interfacetype 都是创建自定义类型的手段,但它们各自有着独特的应用场景和特点。

1️⃣ Interface(接口)

📋 定义

interface 用于描述对象的形状(shape),即一组必须遵循的属性和方法的集合。它可以用于类的实现、函数参数的类型约束,甚至是变量的类型注解。

interface Person {
  name: string;
  age: number;
  greet(): void; // 描述一个方法
}
🤝 实现

类可以实现一个接口,强制类具有接口规定的属性和方法。

class Student implements Person {
  name: string;
  age: number;

  constructor(name: string, age: number) {
    this.name = name;
    this.age = age;
  }

  greet(): void {
    console.log(`Hello, I'm ${this.name} and I'm ${this.age} years old.`);
  }
}
💡 特点
  • 可扩展性:接口可以合并(通过重复声明接口名并添加新成员),实现接口的类或接口可以逐渐积累成员。
  • 面向对象友好:更适合面向对象编程中的抽象定义。

2️⃣ Type Aliases(类型别名)

📜 定义

type 关键字用于创建一个新的名字来引用现有的类型,它可以是原始类型、联合类型、元组类型、甚至其他接口类型。

type StringOrNumber = string | number;
type Point = [number, number];
type Admin = { 
	role: 'admin'; 
	permissions: string[] 
};
🎯 应用
  • 简单替换:简化复杂的类型表达式。
  • 联合类型:定义可以是多种类型的变量。
  • 接口兼容性替代:尽管 type 不能被继承,但可以用来定义对象类型,类似于 interface
🧠 特点
  • 灵活性type 更灵活,可以定义函数类型、元组、联合类型等。
  • 不可扩展:与接口相比,类型别名一旦定义,就不能像接口那样通过合并来扩展。
  • 互斥性:不能用 implements 关键字实现 type,适合非面向对象的场景。

📊 interfacetype 的区别

  • 扩展性interface 支持后续扩展,而 type 不支持。
  • 用途interface 适用于定义对象形状,尤其是面向对象设计;type 更通用,适用于各种类型定义,包括但不限于对象类型。
  • 语法差异interface 可以直接定义方法签名,而 type 定义对象类型时需使用对象字面量形式。

🌟 实践建议

  • 对于需要描述对象结构或实现多态的场景,优先考虑使用 interface
  • 当需要定义复杂的类型组合或函数类型时,使用 type 可能更加简洁和灵活。
  • 根据具体需求和团队编码规范来决定使用哪个,两者并非互斥,经常需要配合使用以达到最佳效果。

🚀 总结

综上所述,interfacetype 都是TypeScript中实现类型安全的重要机制,它们各有千秋,服务于不同的场景需求。

interface凭借其开放性和面向对象的特性,非常适合用于定义和扩展对象结构及类的契约;而type则以其灵活性和多样性,在处理联合类型、元组类型及更复杂的类型定义时展现出独特优势。

开发者应当根据具体的项目需求和代码风格,合理选择使用interfacetype,或是两者结合,以达到最优的类型系统设计。理解它们之间的差异与联系,是每位TypeScript开发者技能提升的重要一环。

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

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

相关文章

深度学习网络:设计、开发和部署

​书籍:Deep Learning Networks: Design, Development and Deployment 作者:Jayakumar Singaram,S. S. Iyengar,Azad M. Madni 出版:Springer书籍下载-《​深度学习网络:设计、开发和部署》该教材为学生和工…

Redis 实战之RDB文件结构

RDB文件结构 databases 部分key_value_pairs 部分value 的编码字符串对象列表对象集合对象哈希表对象有序集合对象INTSET 编码的集合ZIPLIST 编码的列表、哈希表或者有序集合 总结AOF持久化的实现命令追加 AOF 文件的写入与同步小结 在本章之前的内容中, 我们介绍了…

后门通信模型剖析

通信模型剖析 梳理DinodasRAT Linux后门通信模型如下: 发送数据-通信数据结构 #原始数据 20000000e703881435b674f7de23a2f80fe35ac0ba1a46c7d96e08a8747889eacf6b1950#载荷数据 e703881435b674f7de23a2f80fe35ac0ba1a46c7d96e08a8747889eacf6b1950#数据解密 180…

Datasophon基于dinky1.0.1升级到dinky1.0.2

1.首先下载dinky1.0.2版本 dinky1.0.2下载地址 2.关闭dinky1.0.1 3.升级dinky1.0.2 3.1 解压dinky1.0.2.ta.gz tar -xzvf dinky-release-1.16-1.0.2.tar.gz -C /opt/datasophon/rm -rf dinky-release-1.16-1.0.2.tar.gz复制dinky1.0.1的配置文件到dinky1.0.2目录 cp /op…

leetcode91.解码方法(动态规划)

问题描述: 一条包含字母 A-Z 的消息通过以下映射进行了 编码 : A -> "1" B -> "2" ... Z -> "26" 要 解码 已编码的消息,所有数字必须基于上述映射的方法,反向映射回字母(可…

难定取舍,静观其变

今(2024年5月8日)天,本“人民体验官”在推广人民日报官方微博文化产品《带着笑意的眼睛,能看见最美的风景》的同时,还要联系4月初至今期间,与隐藏在《麻辣论坛》幕后的那位昵称“800727”者所爆发的一连串&…

Python:一种强大的编程语言与无限可能

引言 Python是一种易于学习且功能强大的编程语言,它被广泛用于各种领域,包括数据科学、人工智能、Web开发、系统自动化等。Python以其简洁的语法、丰富的库和易于阅读的风格,成为了许多开发者的首选。本文将探讨Python的特性和应用&#xff…

用户下单操作

一:用户下单需求分析和设计: 用户下单业务说明: 在电商系统中,用户是通过下单的方式通知商家,用户已经购买了商品,需要商家进行备货和发货。 用户下单后会产生订单相关数据,订单数据需要能够体…

pytest教程-40-钩子函数-pytest_runtest_call

领取资料,咨询答疑,请➕wei: June__Go 上一小节我们学习了pytest_runtest_setup钩子函数的使用方法,本小节我们讲解一下pytest_runtest_call钩子函数的使用方法。 pytest_runtest_call 钩子函数在 pytest 调用测试函数(即测试用…

探索 JavaScript 宇宙:DOM与BOM的星际邂逅

个人主页:学习前端的小z 个人专栏:JavaScript 精粹 本专栏旨在分享记录每日学习的前端知识和学习笔记的归纳总结,欢迎大家在评论区交流讨论! 文章目录 💯Web API🍀1 API的概念🍀2 Web API的概念…

JavaScript数字分隔符

● 如果现在我们用一个很大的数字,例如2300000000,这样真的不便于我们进行阅读,我们希望用千位分隔符来隔开它,例如230,000,000; ● 下面我们使用_当作分隔符来尝试一下 const diameter 287_266_000_000; console.log(diameter)…

xhs 旋转滑块流程分析

声明 本文章中所有内容仅供学习交流,抓包内容、敏感网址、数据接口均已做脱敏处理,严禁用于商业用途和非法用途,否则由此产生的一切后果均与作者无关,若有侵权,请联系我立即删除! 前言 之前搞过 x-s的纯…

CentOs9编译C指令报错的一种解决方案

今天使用centos9编译c代码时,显示bash: gcc: command not found... 下图是我的报错页面,依据提示信息安装gcc之后依旧显示失败 找到其中一种解决方式,完美解决,供参考 输入以下指令更新软件包列表,这里需要等待几分…

如何有效使用Tacotron系列语音合成模型

谷歌开发的Tacotron系列,主要用于文本到语音(TTS)的转换。模型基于端到端的序列到序列(Seq2Seq)架构,能够直接从文本中生成自然听起来的语音。Tacotron系列是基于神经网络的自回归语音合成模型,…

2024全国计算机专业大学排名前10强名单

根据2024软科中国大学专业排名——计算机科学与技术专业,全国计算机专业最好的5所大学分别是清华大学、浙江大学、北京大学、国防科技大学和北京航空航天大学等, 以下是上大学网(https://www.sdaxue.com/)整理的全国计算机专业&a…

IoTDB 入门教程 基础篇⑤——数据模型和基础概念

文章目录 一、前文二、数据模型2.1 关系型数据库MySQL。2.2 时序数据库TDengine2.3 时序数据库InfluxDB2.4 时序数据库IoTDB(本专栏的正主) 三、基础概念3.1 数据库(Database)3.2 设备模板(元数据模板)3.3 …

如何使用低代码快速创建一个复杂交叉报表?

前言 在当今数字化时代,数据是企业决策和发展的重要支柱。为了更好地理解和利用数据,生成清晰、全面的报表至关重要。而复杂交叉报表作为一种高级数据分析工具,能够帮助企业深入挖掘数据背后的价值,提供全面的数据概览和分析结果…

数据结构-线性表-链表-2.3-1

设计一个递归算法,删除不带头结点的单链表L中所有值为x的结点。 void del(Linkllist &L,int x){LNode *p;if(LNULL){return;}if(L->datax){pL;LL->next;;free(p);del(L,x);}else{del(L->next,x);} } 时间复杂度为O(n)

算法day01

1、[283.移动零](https://leetcode.cn/problems/move-zeroes/) 给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。请注意 ,必须在不复制数组的情况下原地对数组进行操作。 解题思路: 双指针…

重置密码之后无法ssh登录

背景描述 我这边有个服务器S,我从ServerA可以ssh上去,但是我从堡垒机B无法ssh上去;一开始以为是密码问题,手动重置密码,但是依然无法登录进去;一直提示密码错误;改了好几次密码都不行 问题原因…