typescript 闭包类型 高阶函数泛型使用

本文深入探讨了TypeScript中的闭包类型和高阶函数泛型的使用技巧,揭示了如何利用这些特性来实现更强大、更灵活的函数。通过实例解析,读者将了解到如何在函数中保持状态,以及如何通过泛型提升函数的复用性,以适应不同类型的参数和返回值。

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

// 类型定义
interface IClosureGeneric{
  <T extends (...args: any) => any>(fn: T): (...args: Parameters<T>) => ReturnType<T> | void
}

/* 
解释:
1. <T extends (...args: any) => any>
	函数参数前定义泛型参数T,约束T为函数类型
2. Parameters<T>
	Ts工具泛型,用于获取函数的参数类型
3. ReturnType<T>
	Ts工具泛型,用于获取函数的返回类型
*/

// 闭包函数/高阶函数
const withFunction: IClosureGeneric = (fn) => {
  return (...args) => {
  	// do some thing
    return fn(args)
  }
}

// 使用示例
interface IRequestHandle {
  (params: Record<any, any>): void
}
const requestHandle = withFunction<IRequestHandle>((params) => {
	// do some thing
	return http(params)
})

// 这样Ts类型提示就正常工作来


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值