柯里化(不完全函数)实现add函数

    //Currying 柯里化 Partial Function 不完全函数
    function add() { 
        var tmpSlice = [].slice,
            params = tmpSlice.apply(arguments);
        function currying() {
            var arr = tmpSlice.apply(arguments);
            params = params.concat(arr);
            return currying;
        }
        currying.toString = function () {
            var result = 0;
            params.forEach(value => {
                result += value;
            });
            return result;
        }
        return currying;
     }

     console.log(add(1)(2)(3)) // 6
     console.log(add(1,2,3))   // 6

这是一种部分求值技术,能把一个完整的函数调用分解成多次函数调用,每次只传入部分参数,返回一个接收剩下参数的函数,如此循环往复,直到将所有参数传递过去,最后得出结果。
arguments是一个类数组对象, 通过数字索引就能从对象中读取未命名的实参。在函数内部再定义一个函数,在这个内部函数中合并每次传入的实参,并返回自身。然后重写该内部函数的toString()方法,因为每次调用它都会返回其自身,而最后一次输出它(即console.log())的时候就会调用toString()方法,此时计算出所有参数的和,返回即可。

前端问题总结 文章被收录于专栏

总结一些前端常见的面试笔试题,来和大家分享鸭

全部评论

相关推荐

点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务