ts泛型的类

本文详细探讨了TypeScript中的泛型概念,通过实例解释如何在类中使用泛型来提升代码的复用性和类型安全性。从泛型的基本用法,到泛型约束和高级泛型技巧,全方位解析了泛型在前端UI开发中的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

class Point<T>{
x:T
y:T
z:T
constructor(x:T,y:T,z:T) {
this.x=x
this.y=y
this.z:z
}
}
const p=new Point('123','23','231')//类型推导
const p2=new Point<sring>('123','23','231')
const p3:Point<sring>=new Point('123','23','231')
const p4:sring[]=['123','23','231']
const p5:Array<string>=['123','23','231']//开发不推举

<think>好的,用户想了解TypeScript中的用法。首先,我需要回忆一下的基本概念,以及它在TypeScript中的具体应用。主要是用来增强代码的可重用性和安全,允许在定义函数、接口或时不预先指定具体,而是在使用时再指定。 根据用户提供的引用内容,引用[2]提到了如何定义函数,使用<T>来声明,并在函数参数和返回值中使用。引用[1]和引用[3]则涉及接口和的例子。需要把这些内容整理成用户容易理解的步骤。 首先,应该从函数开始讲解,这是最基础的部分。然后介绍接口,说明如何定义带有的接口,并给出例子。接着是,展示在中使用的方法。最后可以提到约束,虽然用户提供的引用中没有直接提到,但这也是的一个重要部分,可以补充说明,比如使用extends关键字限制范围。 需要注意用户提供的示例代码,确保在回答中正确引用这些例子,比如引用[2]中的identity函数,引用[3]中的Hello接口和HelloNumber。要检查这些代码是否符合TypeScript的语法,比如函数和接口的定义是否正确。 用户可能对的使用场景不太清楚,可能需要解释为什么使用,比如避免any带来的信息丢失,提高代码灵活性和安全性。此外,可能还需要提到在数组、Promise等常见场景中的应用,但根据提供的引用,可能需要集中在函数、接口和上。 最后,生成相关问题时要围绕的其他方面,比如约束、默认、高级等,或者与其他语言(如Java、C#)的比较,帮助用户进一步学习。</think>### TypeScript 中的使用方法 (Generics)是 TypeScript 中用于增强代码复用性和安全的重要特性,允许在定义函数、接口或时**不预先指定具体**,而是在使用时动态指定。以下是具体用法: --- #### 1. 函数 定义函数时,使用 `<T>` 声明(`T` 是占位符,可替换为其他名称),参数和返回值均可使用该: ```typescript function identity<T>(arg: T): T { return arg; } // 显式指定 const strResult = identity<string>("hello"); // 为 string // 推断 const numResult = identity(100); // 自动推断为 number ``` **作用**:避免使用 `any` 导致的信息丢失,同时支持多种[^2]。 --- #### 2. 接口 接口中可通过定义灵活的结构: ```typescript interface Hello<T> { (arg: T): T; } function myHello<T>(arg: T): T { return arg; } // 指定接口为 number const mh: Hello<number> = myHello; console.log(mh(100)); // 输出 100 ``` **用途**:常用于回调函数或对象方法的约束[^3]。 --- #### 3. 可以通过定义属性或方法的: ```typescript class HelloNumber<T> { zero: T; add: (x: T, y: T) => T; } // 实例化时指定为 number const myHelloNumber = new HelloNumber<number>(); myHelloNumber.zero = 0; myHelloNumber.add = (x, y) => x + y; console.log(myHelloNumber.add(10, 20)); // 输出 30 ``` **优势**:的内部逻辑可复用,同时保持一致性。 --- #### 4. 约束 通过 `extends` 限制的范围: ```typescript interface Lengthwise { length: number; } function logLength<T extends Lengthwise>(arg: T): void { console.log(arg.length); } logLength("hello"); // 输出 5(字符串有 length 属性) logLength([1, 2, 3]); // 输出 3 ``` **适用场景**:需要满足特定条件时(如必须包含某个属性)。 --- #### 典应用场景 - **数据处理函数**:如排序、转换等需支持多种的工具函数。 - **集合**:数组、栈、队列等容器的实现。 - **API 响应封装**:统一处理不同的数据返回值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

叮咚前端

你的鼓励是我们的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值