# 手写柯里化函数
柯里化是把一个多参数函数转化成一个嵌套的一元函数的过程
# 题目
写一个 curry 函数,可以把其他函数转为 curry 函数
function add(a, b, c) { return a + b + c }
add(1, 2, 3) // 6
const curryAdd = curry(add)
curryAdd(1)(2)(3) // 6
# 解答
代码参考 curry.ts
export function curry(fn: Function) {
const fnArgsLength = fn.length // 传入函数的参数长度
let args: any[] = []
// ts 中,独立的函数,this 需要声明类型
function calc(this: any, ...newArgs: any[]) {
// 积累参数
args = [
...args,
...newArgs
]
if (args.length < fnArgsLength) {
// 参数不够,返回函数
return calc
} else {
// 参数够了,返回执行结果
return fn.apply(this, args.slice(0, fnArgsLength))
}
}
return calc
}
# 单元测试
describe('curry', () => {
it('curry add', () => {
function add(a: number, b: number, c: number): number {
return a + b + c
}
const res1 = add(10, 20, 30)
const curryAdd = curry(add)
const res2 = curryAdd(10)(20)(30)
expect(res1).toBe(res2)
})
})
# 总结
- 判断参数长度
- 中间态返回函数,最后返回执行结果
- 如用 this 慎用箭头函数