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


相关文章

我最大的一个关于TypeScript的问题是,它将原型的所有方法(无...
我对React很新,我正在尝试理解子组件之间相互通信的简洁方法...
我有一个非常简单的表单,我将用户电子邮件存储在组件的状态,...
我发现接口非常有用,但由于内存问题我需要开始优化我的应用程...
我得到了一个json响应并将其存储在mongodb中,但是我不需要的...
我试图使用loadsh从以下数组中获取唯一类别,[{"listing...