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

泛型:像“填空”一样写类型,让你的代码从“复制粘贴”中解放

你是不是遇到过这种场景写了一个函数处理数字的版本写一遍处理字符串的版本再写一遍处理数组的又写一遍……最后代码里全是长得差不多的“双胞胎”。今天我们来学TypeScript的泛型——一个能让你写一次、处处用的“类型模板”。从此告别复制粘贴做个体面的程序员。前言想象一下你开了一家“万能快递公司”。客户要寄书你准备书盒要寄衣服你准备衣服盒要寄手机你准备手机盒……每种物品都要单独设计盒子累不累更好的做法设计一种可调节大小的盒子客户说寄什么你就把盒子调成对应大小。这个“可调节的盒子”就是泛型。TypeScript的泛型让你在定义函数、类、接口时先“留个空”等用的时候再往里填具体类型。这样既保证了类型安全又避免了重复代码。一、泛型长啥样一个简单的例子先看一个没有泛型的“悲惨世界”// 只能处理数字functionidentityNumber(arg:number):number{returnarg;}// 只能处理字符串functionidentityString(arg:string):string{returnarg;}// 要处理布尔值再写一个……用泛型只需要一个functionidentityT(arg:T):T{returnarg;}这里的T就像个“占位符”你调用时可以指定具体类型letoutput1identitystring(hello);// 类型是 stringletoutput2identitynumber(123);// 类型是 number但TS很聪明能自动推断所以通常可以省略letoutputidentity(hello);// TS推断出T为string二、泛型不只是“传进去又返回来”你可以约束参数的类型关系。比如你想让函数接收一个数组并返回数组的第一个元素functiongetFirstT(arr:T[]):T{returnarr[0];}constfirstNumbergetFirst([1,2,3]);// 类型 numberconstfirstStringgetFirst([a,b]);// 类型 stringT帮我们保持了“数组元素类型”和“返回值类型”的一致性。三、泛型约束给“占位符”画个圈有时候你不能让T为所欲为。比如你想写一个函数打印参数的length属性functionlogLengthT(arg:T):T{console.log(arg.length);// ❌ 报错T可能没有lengthreturnarg;}因为T可能是number、boolean它们没有.length。这时候需要约束——告诉TST必须是有length属性的类型。interfaceHasLength{length:number;}functionlogLengthTextendsHasLength(arg:T):T{console.log(arg.length);// ✅ 安全returnarg;}logLength(hello);// 字符串有lengthlogLength([1,2,3]);// 数组有lengthlogLength(123);// ❌ 数字没有length报错extends关键字在这里不是继承而是“约束为某个类型的子集”。四、泛型接口把接口变成“模具”接口也可以泛型化比如定义一个通用的响应结构interfaceApiResponseT{code:number;message:string;data:T;}// 使用typeUser{name:string;age:number};constresponse:ApiResponseUser{code:200,message:success,data:{name:张三,age:18}};这样你就能用一个接口描述所有API返回格式只需替换T。五、泛型类像造模具一样造类类同样可以泛型classQueueT{privatedata:T[][];push(item:T){this.data.push(item);}pop():T|undefined{returnthis.data.shift();}}constnumberQueuenewQueuenumber();numberQueue.push(123);numberQueue.push(456);// ❌ 报错只能放数字六、泛型工具类型TS内置的“变形金刚”TS提供了一些内置的泛型工具能帮你快速转换类型。1.PartialT把属性都变成可选interfaceUser{name:string;age:number;}typePartialUserPartialUser;// { name?: string; age?: number; }2.ReadonlyT把所有属性变成只读typeReadonlyUserReadonlyUser;// { readonly name: string; readonly age: number; }3.PickT, K从T中挑选部分属性typeUserNamePickUser,name;// { name: string; }4.OmitT, K从T中排除部分属性typeUserWithoutAgeOmitUser,age;// { name: string; }还有RecordK, T、Exclude、Extract等遇到具体场景时再查文档即可。七、联合类型与交叉类型不是泛型但常一起用联合类型|这个或那个letvalue:string|number;valuehello;// OKvalue123;// OKvaluetrue;// ❌联合类型适合“不确定具体是哪个但知道是有限的几种”。交叉类型既要又要interfaceName{name:string;}interfaceAge{age:number;}typePersonNameAge;// 同时有name和age属性constp:Person{name:张三,age:18};交叉类型常用来合并多个类型。八、类型保护让TS相信你当你使用联合类型时TS会限制你只能调用所有类型共有的方法。要调用特定类型的方法需要类型保护。functionprintLength(value:string|number){// console.log(value.length); // ❌ 报错number没有lengthif(typeofvaluestring){console.log(value.length);// ✅ 这里TS知道value是string}else{console.log(value.toFixed(2));}}除了typeof还有instanceof、in关键字、自定义类型守卫。九、实战用泛型写一个“万能”的缓存函数interfaceCacheT{get(key:string):T|undefined;set(key:string,value:T):void;}functioncreateCacheT():CacheT{conststore:Recordstring,T{};return{get(key){returnstore[key];},set(key,value){store[key]value;}};}conststringCachecreateCachestring();stringCache.set(name,张三);constnamestringCache.get(name);// 类型是 string | undefinedconstnumberCachecreateCachenumber();numberCache.set(age,18);看一套代码同时服务了字符串缓存和数字缓存类型还完全安全。十、总结泛型是“类型编程”的起点泛型就是“类型的参数”让组件函数、类、接口能适应多种类型同时保留类型关系。约束用extends限定泛型的范围。泛型接口/类让数据结构通用。内置工具类型Partial、Pick等简化常见类型转换。联合类型表示“或”交叉类型表示“且”类型保护用来区分联合中的具体类型。掌握泛型你就能写出更抽象、更复用、更安全的代码。明天我们将继续TypeScript的高级主题——装饰器看看这个类似Java注解的特性如何在TS里玩出花样。如果你觉得今天的“万能模具”讲得通透点个赞让更多人看到。明天我们聊聊装饰器——那个在Angular和NestJS里无处不在的黑魔法。我们明天见

相关文章:

泛型:像“填空”一样写类型,让你的代码从“复制粘贴”中解放

你是不是遇到过这种场景:写了一个函数,处理数字的版本写一遍,处理字符串的版本再写一遍,处理数组的又写一遍……最后代码里全是长得差不多的“双胞胎”。今天我们来学TypeScript的泛型——一个能让你写一次、处处用的“类型模板”…...

代码随想录算法训练营第六天 | Leetcode 454.四数相加 | 383.赎金信 | 15.三数之和 | 18.四数之和

day6 – 哈希表part02 454.四数相加 力扣题目链接:454. 四数相加 II - 力扣(LeetCode)文章讲解:第454题.四数相加II | 哈希表 | map | 统计查找 | 代码随想录视频讲解:学透哈希表,map使用有技巧&#xff…...

YOLO + SubspaceAD:一张良品图,检出所有未知缺陷

YOLO + SubspaceAD:一张良品图,检出所有未知缺陷 当YOLO遇上CVPR 2026子空间建模,工业缺陷检测迎来质变 一、痛点直击:缺陷检测的“三座大山” 第一座山:缺陷样本少,种类严重失衡。 工业生产追求“零缺陷”,导致真实缺陷样本极度稀缺,每十万件产品中往往仅出现3—5件次…...

CMake Converter终极指南:三步实现Visual Studio到CMake的自动化迁移

CMake Converter终极指南:三步实现Visual Studio到CMake的自动化迁移 【免费下载链接】cmakeconverter This project aims to facilitate the conversion of Visual Studio to CMake projects. 项目地址: https://gitcode.com/gh_mirrors/cm/cmakeconverter …...

来画AI漫剧软件2025推荐,创新故事创作工具引领未来

来画AI漫剧软件2025推荐,创新故事创作工具引领未来一、引言随着科技的快速发展,越来越多的创新工具正在改变我们的创作方式。来画AI漫剧软件作为一款集成了人工智能技术的故事创作工具,正逐渐成为创作者们的新宠。本文将从多个维度详细解析来…...

零硬件也能玩!OpenClaw仿生机器人入门全指南:从环境搭建到第一个机械臂抓取项目

很多刚接触仿生机器人的同学,第一次听说OpenClaw,都会被它“仿生龙虾机器人”的名头劝退,觉得这是个只有硬件图纸、没有实操教程的学术项目。我去年第一次接触OpenClaw的时候,光是环境搭建就踩了一周的坑:ROS版本不对、…...

不会做Twitter运营?用赛博云推,一套自动化流程帮你实现涨粉+获客+霸屏

在如今的社交媒体环境中,Twitter(X) 已经成为流量竞争最激烈的平台之一。无论是跨境电商、独立站推广,还是个人IP打造,越来越多的人开始布局Twitter。但很多人在实际操作中都会遇到一个核心问题:做了很久&a…...

HunyuanVideo-Foley部署教程:RTX4090D专属优化版开箱即用完整指南

HunyuanVideo-Foley部署教程:RTX4090D专属优化版开箱即用完整指南 1. 环境准备与快速部署 HunyuanVideo-Foley是一款强大的视频生成与音效生成工具,本教程将指导您在RTX 4090D显卡上快速部署优化版镜像。这个专为24GB显存优化的版本,让您无…...

2026制造企业产品交付周期缩短专项:6款项目管理系统选型分析

核心目标:聚焦制造企业计划协同、跨部门联动、风险前置、行业适配、落地提效五大交付周期核心痛点,梳理6款主流项目管理系统的功能特性、适配场景与核心优劣势,为制造企业结合自身需求精准选型提供客观参考依据。 一、制造企业选型核心维度&…...

7脚 LED数码屏的刷新显示,乱码请指正

我是新手近段时间的工作是点亮7脚LED数码屏,刷新时遇到了困惑请大家帮助指正,在此表示非常感谢。 下面是7脚LED数码屏结构图。 用了7个 case下面是刷新代码switch(ScanPinNum){// ---------------- CASE1: PIN1------------------------case 1: …...

局域网基本原理

1.局域网技术 a.以太网Ethernet b.令牌环 token ring 由IBM公司开发,IEEE802.5就是在此基础上i.工作模式:需要发送数据的时候,需要等待空闲令牌收到后,才能发送,令牌是一种特殊的MAC控制帧 c.FDDI 光纤分布式数据接口i…...

[资源] 【百度网盘 】最终幻想战略版 伊瓦利斯编年史 豪华中文 Build.20688883+全DLC-支持手柄

受太阳与圣印保佑,由双头狮统治的国家――――Ivalice。Ivalice与邻国Ordallia展开“The Fifty Years’ War”却战败。一年后先王病逝,而将要继承王位的王子年仅两岁。此后为争夺监护人的头衔与实权,在“The Fifty Years’ War”立下战功的两…...

出厂自带“缰绳”的AI来了,Hermes Agent正在重新定义智能体

在过去的一年里,AI Agent领域经历了一场又一场热潮,OpenClaw带来的“龙虾热”还没有完全散去,一款名为Hermes Agent的开源智能体框架又迅速闯入开发者视野。发布短短两个月,GitHub星标就突破27000,没有铺天盖地的营销&…...

HTML 5段落

HTML5 段落 (Paragraphs) 学习笔记 在 HTML5 中&#xff0c;段落是文本内容的基本构建块。虽然核心标签 <p> 从 HTML4 继承而来&#xff0c;但 HTML5 在语义化结构、文本流控制以及与语义标签的配合方面有了更明确的规范。一、核心标签&#xff1a;<p> 1. 基本用法…...

别再数据线了!用FastAPI 分钟搭个局域网文件+剪贴板神器志

为 HagiCode 添加 GitHub Pages 自动部署支持 本项目早期代号为 PCode&#xff0c;现已正式更名为 HagiCode。本文记录了如何为项目引入自动化静态站点部署能力&#xff0c;让内容发布像喝水一样简单。 背景/引言 在 HagiCode 的开发过程中&#xff0c;我们遇到了一个很现实的问…...

HTML5 标题

HTML5 标题 (Headings) 学习笔记 HTML5 中的标题元素用于定义文档的层级结构。它们对于文档结构、**SEO&#xff08;搜索引擎优化&#xff09;以及无障碍访问&#xff08;Accessibility&#xff09;**至关重要。 一、标题元素概览 HTML 提供了 6 个级别的标题&#xff0c;从最…...

OpenTiny NEXT 从入门到精通·第 6 篇

OpenTiny NEXT 从入门到精通第 6 篇&#xff1a;架构篇——跨框架集成与微前端实战在企业级前端开发中&#xff0c;多技术栈共存、存量系统迁移、微前端集成是绕不开的三大难题。你可能正在维护一个 Vue 2 的老项目&#xff0c;新业务要用 Vue 3 开发&#xff0c;团队中还有 Re…...

RPA入门,看这篇就够了

一、基础定义&#xff1a;RPA究竟是什么&#xff1f; 机器人流程自动化&#xff08;Robotic Process Automation&#xff0c;简称RPA&#xff09;是一种通过软件程序模拟人类在计算机上的操作行为&#xff0c;依据预设规则自动执行重复性、规则性任务的应用软件技术。简单来说&…...

OpenClaw自动化招聘工具:千问3.5-35B-A3B-FP8筛选简历截图并生成面试问题

OpenClaw自动化招聘工具&#xff1a;千问3.5-35B-A3B-FP8筛选简历截图并生成面试问题 1. 为什么需要自动化招聘工具 去年帮朋友公司处理校招季简历时&#xff0c;我深刻体会到人工筛选的痛点&#xff1a;连续三天熬夜翻阅800多份PDF简历&#xff0c;眼睛酸胀不说&#xff0c;…...

call、apply和bind的原理及使用场景

在JavaScript 中&#xff0c;call、apply 和 bind 是 Function 对象自带的三个方法&#xff0c;这三个方法的主要作用是改变函数中的 this 指向&#xff0c;从而可以达到接花移木的效果 原理&#xff1a; 1、call(thisArgs [,args...]) 该方法可以传递一个thisArgs参数和一个…...

Swoole vs RoadRunner vs PHP-PM:异步I/O配置参数对比表(含内存泄漏率、上下文切换耗时、FD复用率实测)

第一章&#xff1a;Swoole vs RoadRunner vs PHP-PM 异步I/O配置全景概览现代PHP高性能服务化方案中&#xff0c;Swoole、RoadRunner 和 PHP-PM 均通过常驻内存与异步I/O机制突破传统PHP-FPM的阻塞模型&#xff0c;但其实现路径、依赖模型与配置范式存在本质差异。三者均不依赖…...

AI Agent 安全养虾实战:从零基础到专家的阿里云全栈进阶指南

开篇 通关前置认知&#xff1a;为什么AI Agent时代&#xff0c;“安全养虾”是从业者的必修课&#xff1f; 2024-2026年&#xff0c;AI Agent迎来产业级爆发拐点&#xff0c;“养虾”一跃成为横跨数字科技与实体农业两大赛道的全民热词&#xff0c;其背后是两大万亿级市场的核心…...

OPUS编解码器在audio DSP上的移植和应用吨

前言 在使用 kubectl get $KIND -o yaml 查看 k8s 资源时&#xff0c;输出结果中包含大量由集群自动生成的元数据&#xff08;如 managedFields、resourceVersion、uid 等&#xff09;。这些信息在实际复用 yaml 清单时需要手动清理&#xff0c;增加了额外的工作量。 使用 kube…...

C语言-------聚合数据类型

一、结构体1.结构体概念与创建结构体&#xff08;Struct&#xff09;是在编程中用于组合多个相关数据项的复合数据类型&#xff0c;它允许将不同类型的数据&#xff08;如整数、字符、数组&#xff0c;甚至其他结构体&#xff09;聚集在一起&#xff0c;形成一个逻辑上的整体&a…...

一款基于 .NET 开源、跨平台应用程序自动升级组件奈

基础示例&#xff1a;单工作表 Excel 转 TXT 以下是将一个 Excel 文件中的第一个工作表转换为 TXT 的完整步骤&#xff1a; 1. 加载并读取Excel文件 from spire.xls import * from spire.xls.common import * workbook Workbook() workbook.LoadFromFile("示例.xlsx"…...

不用装软件!这款MicroPython浏览器 IDE :让你在手机上也能调试树莓派 Pico亚

1、普通的insert into 如果&#xff08;主键/唯一建&#xff09;存在&#xff0c;则会报错 新需求&#xff1a;就算冲突也不报错&#xff0c;用其他处理逻辑 回到顶部 2、基本语法&#xff08;INSERT INTO ... ON CONFLICT (...) DO (UPDATE SET ...)/(NOTHING)&#xff09; 语…...

彻底搞懂词元(Token)!小白科普,看完再也不懵

不管是用ChatGPT、豆包这类AI工具&#xff0c;还是刷AI相关的科普内容&#xff0c;你一定绕不开一个词——词元&#xff08;Token&#xff09;。 “AI生成内容有词元&#xff08;Token&#xff09;限制”“付费按词元&#xff08;Token&#xff09;计价”“训练AI要先分词元&a…...

中设智控亮相陕西设备管理工作会议,AI赋能方案引领智能运维新变革

2026年3月25日-27日&#xff0c;2026年陕西省设备管理与装备制造工作会议在陕西省汉中市成功召开。本次会议聚焦装备制造业高质量发展与设备管理智能化升级&#xff0c;吸引了众多行业专家与企业代表参会。广东中设智控科技股份有限公司&#xff08;以下简称 “中设智控”&…...

食品行业设备管理系统:筑牢合规追溯防线,规范清洁维护记录

食品行业的核心底线是“安全与合规”&#xff0c;而生产设备作为食品加工的核心载体&#xff0c;其清洁度、运行状态、维护记录直接决定食品质量&#xff0c;更是应对SC、HACCP、ISO22000等合规审计的关键。不同于其他行业&#xff0c;食品生产设备&#xff08;如搅拌罐、灌装机…...

落地即能用!声振温监测部署全流程:设备在线状态监控搭建指南

设备在线状态监控的核心&#xff0c;是通过声振温三大核心数据&#xff0c;捕捉设备隐性故障前兆&#xff0c;实现“早发现、早预警、早处置”&#xff0c;避免非计划停机。而声振温监测的部署&#xff0c;并非简单的“装传感器、连系统”&#xff0c;需遵循科学流程&#xff0…...