柯里化函数的经典写法

// 实现一个add方法,使计算结果能够满足如下预期:
add(1)(2)(3) = 6;
add(1, 2, 3)(4) = 10;
add(1)(2)(3)(4)(5) = 15;

function add() {
    // 第一次执行时,定义一个数组专门用来存储所有的参数
    var _args = Array.prototype.slice.call(arguments); // 等价于arguments.slice()

    // 在内部声明一个函数,利用闭包的特性保存_args并收集所有的参数值
    var fn = function() {
        _args.push(...arguments);
        return fn;
    };

    // 利用toString隐式转换的特性,当最后执行时隐式转换,并计算最终的值返回
    fn.toString = function () {
        return _args.reduce(function (a, b) {
            return a + b;
        });
    }
    return fn;
}

add(1)(2)(3)                // 6
add(1, 2, 3)(4)             // 10
add(1)(2)(3)(4)(5)          // 15
add(2, 6)(1)                // 9

 

posted @ 2021-03-11 11:15  遗失的王者之心  阅读(93)  评论(0编辑  收藏  举报