当前位置: 首页 > article >正文

前端TypeScript学习-交叉类型与泛型

交叉类型和泛型是TypeScript中的两个重要概念。

交叉类型(&)可以用来组合多个接口,形成一个新接口。它类似于接口继承(extends),但有一些区别。交叉类型不会产生类型继承层次结构,而是将多个接口类型合并成一个新类型。

泛型则是一种在保证类型安全前提下,让函数等与多种类型一起工作,从而实现复用的机制。泛型常用于函数、接口、class中。

交叉类型(Intersection Types)

示例:


type Person = {  
    name: string;  
    age: number;  
};  
  
type Employee = {  
    salary: number;  
    department: string;  
};  
  
type PersonAndEmployee = Person & Employee; // 交叉类型  
  
function printInfo(person: Person): void {  
    console.log(`Name: ${person.name}, Age: ${person.age}`);  
}  
  
function printInfo(employee: Employee): void {  
    console.log(`Salary: ${employee.salary}, Department: ${employee.department}`);  
}  
  
let pae: PersonAndEmployee = {  
    name: "John",  
    age: 30,  
    salary: 50000,  
    department: "Engineering"  
};  
  
printInfo(pae); // 输出:Salary: 50000, Department: Engineering,因为 pae 既是 Person 又是 Employee

上面示例我们定义了两个类型:Person 和 Employee。Person 类型具有 name 和 age 属性,Employee 类型具有 salary、department 和 title 属性。通过使用交叉类型,我们可以创建一个同时具有 Person 和 Employee 属性的新类型 PersonAndEmployee。然后我们定义了一个 printInfo 函数,它可以接受 Person 或 Employee 类型的参数,并打印相应的信息。最后,我们创建了一个 PersonAndEmployee 类型的变量 pae,并使用 printInfo 函数打印了它的信息。由于 pae 既是 Person 又是 Employee,因此我们可以使用任意一个 printInfo 函数来打印它的信息。

优点:

方便类型定义:通过交叉类型,可以将多个接口或类型组合成一个新类型,使得类型定义更加灵活和方便。
提高代码复用:交叉类型可以在不同的类型之间共享某些属性,从而实现代码复用。

缺点:

类型复杂:交叉类型的类型定义比较复杂,容易使代码的可读性降低。
类型限制:交叉类型会限制所组合类型的属性,如果某个属性在组合类型中没有定义,则该属性不能被赋值给组合类型的变量。

使用场景:

UI组件:可以将用户界面组件定义为交叉类型,例如一个按钮组件可以同时具有“默认按钮”和“强调按钮”的属性。
对象封装:可以将对象的属性和方法定义为交叉类型,例如一个对象可以同时具有“用户信息”和“可编辑用户信息”的属性。

泛型(Generics)

示例:


function printMessage<T>(message: T): void {  
    console.log(message);  
}  
  
printMessage("Hello"); // string 类型参数  
printMessage(123); // number 类型参数  
printMessage({ key: "value" }); // object 类型参数

上面示例我们定义了一个泛型函数 printMessage,它接受一个类型参数 T,并打印一个 T 类型的消息。在调用 printMessage 函数时,我们可以传入任意类型的参数,例如 string、number 或 object。TypeScript 会根据传递的参数类型推断出 T 的类型,并确保传递的参数类型与 T 类型匹配。这样,我们就可以使用泛型来处理不同类型的消息,而无需为每种类型编写不同的代码。

优点:

类型安全:泛型可以确保类型在传递给函数或类时不会出现类型错误。
提高代码复用:泛型可以用于处理不同的数据类型,使得代码更加通用和复用。
类型推断:TypeScript 可以自动推断泛型参数的类型,使得代码更加简洁和易读。

缺点:

代码冗余:使用泛型时需要显式指定泛型参数的类型,这可能会导致代码冗余。
类型限制:泛型参数受到类型的限制,不能使用任意类型作为泛型参数。

使用场景:

函数参数:可以使用泛型来定义函数的参数类型,以便函数可以接受不同类型的数据。
接口定义:可以使用泛型来定义接口的类型,以便接口可以适用于不同类型的数据。


http://www.kler.cn/news/106812.html

相关文章:

  • [已解决]安装的明明是pytorch-gpu,但是condalist却显示cpu版本,而且torch.cuda.is_available 也是flase
  • 贪心算法学习——最大数
  • Maven第三章:IDEA集成与常见问题
  • SpringCloud Alibaba【三】Gateway
  • MySQL数据库——视图的更新、视图作用以及案例
  • LuatOS-SOC接口文档(air780E)--libgnss - NMEA数据处理
  • 【洛谷 P3654】First Step (ファーストステップ) 题解(模拟+循环枚举)
  • 增强常见问题解答搜索引擎:在 Elasticsearch 中利用 KNN 的力量
  • 2023年MathorCup高校数学建模挑战赛大数据挑战赛赛题浅析
  • 用Python做数据分析之数据筛选及分类汇总
  • 【Python机器学习】零基础掌握gaussian_process高斯过程中的核函数
  • Python通过pyecharts对爬虫房地产数据进行数据可视化分析(一)
  • 自定义一个注解,用它标记的执行并于给定值做对比(即简单的junit)
  • 王道p149 7.二叉树按二叉链表形式存储,写一个判别给定二叉树是否是完全二叉树的算法(c语言代码实现)
  • APScheduler-调度器AsyncIOScheduler
  • Ansible任务控制loop循环、when和block条件判断介绍演示
  • Leetcode刷题详解——点名
  • LeetCode75——Day18
  • 浏览器下载视频插件使用
  • postgis ST_ClipByBox2D用法
  • centos7安装mysql
  • asp.net core获取config和env
  • 推荐一本书《变速领导力》
  • 论文阅读 - Learning Human Interactions with the Influence Model
  • Go 语言操作 MongoDb
  • 23 行为型模式-迭代器模式
  • node实战——搭建带swagger接口文档的后端koa项目(node后端就业储备知识)
  • 使用pycharm远程调试
  • MySQL视图的使用和优化
  • Spring Cloud之微服务