javascript怎样进行函数柯里化?_javascript的函数组合有什么技巧?

函数柯里化是将多参函数转为单参函数链,通过闭包逐步收参、延迟执行;函数组合则串联单参函数,让数据从右向左流动。二者结合可提升代码复用性、可测试性与表达力。

函数柯里化和函数组合是函数式编程中的两个核心技巧,它们能让 JavaScript 代码更灵活、可复用、易测试。

怎样手动实现函数柯里化?

柯里化是把一个接收多个参数的函数,转换为一系列只接收一个参数的函数的过程。关键在于“逐步收参、延迟执行”。

  • 基础写法:用闭包保存已传入的参数,直到参数数量足够才真正调用原函数
  • 通用柯里化函数支持任意参数个数,通常通过 length 属性判断形参个数
  • 注意:箭头函数没有 argumentslength(绑定到外层),需用普通函数

示例:

function curry(fn) {
  return function curried(...args) {
    if (args.length >= fn.length) {
      return fn.apply(this, args);
    } else {
      return function(...moreArgs) {
        return curried.apply(this, args.concat(moreArgs));
      };
    }
  };
}

如何用柯里化提升实用性?

不是为了炫技,而是解决真实问题:固定部分参数,生成专用函数。

  • 比如 add = (a, b) => a + b,柯里化后 add10 = curry(add)(10),再调用 add10(5) 得到 15
  • 处理事件处理器时,预设配置或 ID:handleClick = curry(updateItem)(userId)
  • 与数组方法配合:[1,2,3].map(curry(Math.pow)(2)) → 平方数组

函数组合的基本技巧

组合(compose)是把多个单参函数串起来,让数据从右向左流过每个函数,即 f(g(h(x))) 等价于 compose(f, g, h)(x)

  • 最简实现:const compose = (...fns) => x => fns.reduceRight((acc, f) => f(acc), x)
  • 推荐从右到左(数学惯例),也有人习惯 pipe(从左到右),本质一致,选一种并保持统一
  • 组合函数必须是纯函数、单参数;多参数函数需先柯里化再组合

例子:

const toUpper = s => s.toUpperCase();
const exclaim = s => s + '!';
const shout = compose(exclaim, toUpper);
shout('hello'); // 'HELLO!'

柯里化 + 组合 = 更强表达力

两者常一起用:先柯里化获得可组合的单元,再用组合构建逻辑流水线。

  • 如处理用户数据:const getActiveNames = compose(map(get('name')), filter(get('active')), get('users')),其中 get = curry((k, obj) => obj[k])
  • 避免中间变量,逻辑一目了然;每个小函数职责单一,便于复用和测试
  • 注意调试:组合链过长时,可用带日志的中间函数临时插入观察

基本上就这些。不复杂但容易忽略——关键是理解“拆分”和“连接”的思想,而不是死记语法。