TS 泛型

泛型(宽泛的,不确定的类型)

  • 使用场景:定义一个函数或类时,无法确定要使用的具体类型(返回值、参数、属性的类型不能确定)
  • 泛型使用时相当于一个参数
javascript 复制代码
functiondemo<T>(arg: T): T{
   return arg;
}
// 泛型T可以看做一个变量
demo<number>(10)
demo<string>('你好')
// 基本类型可以不加泛型
demo(true)
demo(10)
泛型结合接口
javascript 复制代码
interface Param<A,B> {
   title: string,
   state: A,
   list: B[]
}

type ListType = {name:string,age:number}
const p1: Param<boolean,ListType> = {
   title: '泛型和接口结合使用',
   state: true,
   list: [
      {name:'张三',age:18},
      {name:'李四',age:16},
   ]
}
泛型继承
javascript 复制代码
// 泛型的继承(对泛型的约束)
function getLength<T extends { length:number }>(arg: T): number{
   return arg.length;
}
getLength([1,2,3,'4']) // 4
getLength('nihao') // 5

function getLength<T extends string | any[]>(arg: T): number{
   return arg.length;
}
getLength([1,2,3,'4']) // 4

// 当使用T[]时,T表示的是数组参数的元素类型
function getLength<T>(arg: T[]): number{
   return arg.length;
}
getLength<string | number>(['张三','李四',10]) // 3
类中使用泛型
javascript 复制代码
// 类中使用泛型
class MyClass<T>{
   prop: T;

   constructor(prop: T){
      this.prop = prop;
   }
}
// 泛型是一个type
type User = {name:string,age:number}
const user1:User = {name:'张三',age:18}
const c1 = new MyClass<User>( user1 )
// 泛型是基本类型
const c2 = new MyClass<string>('张三')
相关推荐
爱吃的小肥羊2 小时前
比 Claude Code 便宜一半!Codex 国内部署使用教程,三种方法任选一!
前端
IT_陈寒3 小时前
SpringBoot项目启动慢?5个技巧让你的应用秒级响应!
前端·人工智能·后端
树上有只程序猿4 小时前
2026低代码选型指南,主流低代码开发平台排名出炉
前端·后端
橙某人4 小时前
LogicFlow 小地图性能优化:从「实时克隆」到「占位缩略块」!🚀
前端·javascript·vue.js
高端章鱼哥4 小时前
为什么说用OpenClaw对打工人来说“不划算”
前端·后端
大脸怪4 小时前
告别 F12!前端开发者必备:一键管理 localStorage / Cookie / SessionStorage 神器
前端·后端·浏览器
Mr_Mao4 小时前
我受够了混乱的 API 代码,所以我写了个框架
前端·api
小徐_23334 小时前
向日葵 x AI:把远程控制封装成 MCP,让 AI 替我远程控制设备
前端·人工智能
boooooooom4 小时前
讲清 Proxy + effect + track/trigger 流程
javascript·vue.js·面试
冴羽4 小时前
来自顶级大佬 TypeScript 之父的 7 个启示
前端·typescript