JavaScript组合函数是将多个函数串联执行的编程思想,核心为数据流从右向左或从内到外,常用pipe(从左到右)和compose(从右到左),依赖纯函数与一元函数,常配合Ramda等工具库使用。
JavaScript 组合函数(Function Composition)是指把多个函数像积木一样串起来,让前一个函数的输出自动成为后一个函数的输入,最终形成一个新函数。它不是语言内置语法,而是一种编程思想,核心是“数据流从右向左”或“从内到外执行”,常见于函数式编程风格。
最常用的两种组合方式:
pipe(f, g, h)(x) 等价于 h(g(f(x)))
co
mpose(h, g, f)(x) 也等于 h(g(f(x)))
现代 JS 常用 pipe,更符合阅读直觉。你可以自己写一个轻量版:
比如想把一段文本转大写、去空格、取前5个字符:
const toUpper = s => s.toUpperCase();注意顺序:先 trim 再 toUpper 最后 take5,逻辑清晰,每个函数职责单一。
Ramda 提供了开箱即用的 R.pipe 和 R.compose,还自带大量柯里化函数,组合更顺滑:
Lodash 则有 flow(等价于 pipe)和 flowRight(等价于 compose)。
组合函数效果好,依赖两个关键点:
例如:const add = (a, b) => a + b 不适合直接组合,但柯里化后:const add = a => b => a + b; const add10 = add(10); 就可以放进 pipe 了。
基本上就这些。组合函数本身不复杂,但容易忽略函数设计是否适合组合——保持单职责、少副作用、优先一元,组合才真正有用。