JS函数柯里化
维基百科上说道:柯里化,英语:Currying(果然是满满的英译中的既视感),是把接受多个参数的函数变换成接受一个单一参数(最初函数的第一个参数)的函数,并且返回接受余下的参数而且返回结果的新函数的技术。
柯里化作用
1.延时计算,又叫惰性求值。柯里化后的 函数是分步执行的,前几次调用均返回一 个函数,累积传入的参数,最后调用才会 计算,起到延时计算的作用。如bind函 数,改变this指向但并不执行,只返回函
2.固定易变因素。提前将易变因素传参 定下来,生成一个更明确的应用函数。
3.参数复用。当多次调用同一个函数,并 且传递的参数绝大多数是相同的时候。
4.动态创建函数。先完成部分传参, 创建新的函数返回,在需要的时候传入其余的参数调用执行。
// 把第一种函数的形式变成第二种的形式,这个就叫做函数柯里化的过程 fn(2, 3, 4) fn(2)(3)(4) = 24 // 普通写法 function fn(a, b, c) { return a * b * c } // 柯里化的写法(变形) function fn(a) { return function (b) { return function (c) { return a * b * c } } } console.log(fn(1, 2, 3)) // 6 console.log(fn(1)(2)(3)) // 6 // 柯里化调用 - 公共参数提取 let ft = fn(1) console.log(ft(2)(3)) console.log(ft(4)(5)) console.log(ft(6)(7))
// 实现一个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); // 在内部声明一个函数,利用闭包的特性保存_args并收集所有的参数值 var _adder = function() { _args.push(...arguments); return _adder; }; // 利用toString隐式转换的特性,当最后执行时隐式转换,并计算最终的值返回 _adder.toString = function () { return _args.reduce(function (a, b) { return a + b; }); } return _adder; } add(1)(2)(3) // 6 add(1, 2, 3)(4) // 10 add(1)(2)(3)(4)(5) // 15 add(2, 6)(1) // 9