TypeScript - 泛型 - 泛型方法中泛型的使用

对泛型的一个自我理解

复制代码
泛型的使用,实际上就像一个占位符一样,
我先预定义一个类型,这个类型具体是啥只有在真正使用的时候才知道。

从某种角度来看,泛型很像这个 any 类型啊。

泛型的定义语法

复制代码
泛型的定义使用 <T> 的方式来定义,
其中 T 就是你与定义的类型,这个字母可以随便用,无所谓,只是一个符号而已。

泛型定义的时候可以定义多个,只需要在<>中用 逗号隔开就可以。
例如 : <A,B>

写一个常规的泛型方法看看

复制代码
需求描述 :
    写一个函数,
    两个参数,参数1 是泛型类型的,参数2 是一个数字;
    返回值是 创建【参数2】个 【参数1】 的数组。

代码实现如下:
ts 复制代码
// 泛型方法的定义 <T> 声明了一个泛型,在参数列表中、方法体中可以使用这个泛型。
function getArry<T> (value:T,count:number):T[]{
    let arr:T[] = []
    for(let i = 0;i < count;i++){
        arr.push(value)
    }
    return arr
}


// 使用的时候指明范型的类型
console.log(getArry<number>(100,3))
// 使用类型推断自行决定泛型的类型
console.log(getArry("aabbcc",3))
复制代码
运行结果如下 :
[ 100, 100, 100 ]
[ 'aabbcc', 'aabbcc', 'aabbcc' ]

泛型方法的其他写法(了解)

复制代码
因为函数有 函数声明 和 函数表达式 的定义方式。
上面的案例使用的是 函数声明的方式 使用的泛型,
下面 使用 函数表达式的方式 使用一下泛型,实现的效果与上面的案例是一致的。
ts 复制代码
// 函数表达式的方式
const getArry2 = function <T>(value:T,count:number):T[]{
    let arr:T[] = []
    for(let i = 0;i < count;i++){
        arr.push(value)
    }
    return arr
}

// 箭头函数的方式
const getArry3 = <T>(value:T,count:number):T[]=>{
    let arr:T[] = []
    for(let i = 0;i < count;i++){
        arr.push(value)
    }
    return arr
}

多个泛型参数的写法

复制代码
多个符号用逗号隔开即可,如 <T,U,B>
写个例子一看就明白了:
ts 复制代码
// 范型参数可以有多个,用逗号隔开
function getArry4<T,U> (value:T,value2:U,count:number):void{
	// 使用第一个泛型
    let arr:T[] = []
    for(let i = 0;i < count;i++){
        arr.push(value)
    }
	// 使用第二个泛型
    let arr2:U[] = []
    for(let i = 0;i < count;i++){
        arr2.push(value2)
    }

    console.log(arr)
    console.log(arr2)
 
}

// 使用一下
getArry4(100,"bcd",2)
复制代码
运行结果:
[ 100, 100 ]
[ 'bcd', 'bcd' ]
相关推荐
韩立学长1 小时前
【开题答辩实录分享】以《基于Vue的非遗文化知识分享平台的设计与实现》为例进行选题答辩实录分享
前端·javascript·vue.js
优弧1 小时前
离开舒适区100天,我后悔了吗?
前端·后端·面试
胡gh1 小时前
css的臂膀,前端动效的利器,还是布局的“隐形陷阱”?
前端·css·html
灵感菇_2 小时前
Flutter Riverpod 完整教程:从入门到实战
前端·flutter·ui·状态管理
用户21411832636022 小时前
紧急修复!Dify CVE-2025-55182 高危漏洞,手把手教你升级避坑
前端
前端 贾公子2 小时前
Vue响应式原理学习:基本原理
javascript·vue.js·学习
飛6792 小时前
从 0 到 1 掌握 Flutter 状态管理:Provider 实战与原理剖析
开发语言·javascript·ecmascript
Vic101012 小时前
解决 Spring Security 在异步线程中用户信息丢失的问题
java·前端·spring
wordbaby3 小时前
Expo (React Native) 最佳实践:TanStack Query 深度集成指南
前端·react native
~无忧花开~3 小时前
Vue二级弹窗关闭错误解决指南
开发语言·前端·javascript·vue.js