微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

// 类型定义
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类型提示就正常工作来


版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐