JavaScript组合函数是将多个函数串联执行的编程思想,核心为数据流从右向左或从内到外,常用pipe(从左到右)和compose(从右到左),依赖纯函数与一元函数,常配合Ramda等工具库使用。

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











