一道柯里化面试题

这是一道朋友在群里发的一道题,我以前不是很懂柯里化,就本身试着写了一下,不知道算不算柯里化,望指教~

下面是题目:

function curry() {
        // your code.....
    }
    ================================
    //写好以后一下代码能够正常运行输入正确
    function add(a, b, c) {
        return a + b + c;
    }
    
    let addEx = curry(add);

    console.log(addEx(1,2,3) === 6);
    console.log(addEx(1,2)(3) === 6);
    console.log(addEx(1)(2,3) ===6);
    console.log(addEx(1)(2)(3)===6);

    function multi(a, b, c, d) {
        return a * b * c * d
    }
    
    const multiEx = curry(multi)

    console.log(multiEx(2, 3, 4, 5) === 120) //=>true
    console.log(multiEx(2, 3, 4)(5) === 120) //=>true
    console.log(multiEx(2, 3)(4, 5) === 120) //=>true
    console.log(multiEx(2)(3)(4)(5) === 120) //=>true

我本身的代码:

function curry(fn) {
            let len = fn.length;
            let arr = [];
            let getCurry = function () {
                return function () {
                    let next = [...arguments];
                    if (len !== arr.length + next.length) {
                        arr.push(...next);
                        return getCurry();
                    } else {
                        let result =  fn.apply(null, [...arr,...next])
                        arr = []
                        return result
                    }
                }
            }
            return getCurry()
        }

我用到了如下知识点:数组

  1. 扩展运算符传参和扩展运算符相关的数组操做。
  2. 因为是连环调用函数,我用全部调用函数的参数个数来判断。
相关文章
相关标签/搜索