【TypeScript】TS泛型讲解及其使用




// 定义一个函数,它接受两个参数,一个是T,另一个是返回T类型的函数
function identity<T>(arg: T): T {
    return arg;
}
 
// 使用identity函数,TS编译器会推断T的类型
let output = identity<string>("myString");  // output的类型为string
 
// 使用类型推断,不显式传入T
let output2 = identity("myString");  // output2的类型也为string
 
// 定义一个函数,它接受一个数组和一个数字,返回数组中第n个元素的类型
function getArrayElement<T>(arr: T[], n: number): T {
    return arr[n];
}
 
// 使用getArrayElement函数
let secondElement = getArrayElement([1, 2, 3], 1);  // secondElement的类型为number
 
// 定义一个对象,键和值都是T的类型
function mapObject<T>(obj: { [key: string]: T }): T[] {
    return Object.keys(obj).map(key => obj[key]);
}
 
// 使用mapObject函数
let values = mapObject({ name: "Alice", age: 25 });  // values的类型为(string | number)[]
 
// 定义一个函数,它接受两个参数,一个是T,另一个是一个函数,这个函数接受一个T类型的参数并返回一个U类型
function convertArray<T, U>(arr: T[], converter: (item: T) => U): U[] {
    return arr.map(converter);
}
 
// 使用convertArray函数
let converted = convertArray([1, 2, 3], item => item.toString());  // converted的类型为string[]

这段代码展示了如何在TypeScript中定义和使用泛型函数。每个函数都接受不同类型的参数,并返回期望的类型。这有助于提高代码的可重用性和类型安全性。

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日