函数柯里化是将多参数函数转换为单参数函数序列,组合则是将多个函数串联执行。通过curry实现参数累积,compose或pipe实现函数流水线,二者结合可构建灵活的数据处理链,如transform = pipe(trim, toUpper, wrap('div')),提升代码复用与可读性。

函数柯里化和组合是函数式编程中的两个核心概念,它们能帮助我们写出更简洁、可复用且易于测试的代码。在JavaScript中,由于函数是一等公民,这两种技术尤为实用。
柯里化(Currying)是指将一个接受多个参数的函数转换成一系列只接受一个参数的函数。每次调用返回一个新的函数,直到所有参数都被传入并执行最终计算。
例如,一个加三个数的函数:
function add(a, b, c) {
return a + b + c;
}
柯里化后可以这样使用:
立即学习“Java免费学习笔记(深入)”;
const curriedAdd = curry(add); curriedAdd(1)(2)(3); // 6
实现一个通用的柯里化函数:
function curry(fn) {
return function curried(...args) {
if (args.length >= fn.length) {
return fn.apply(this, args);
} else {
return function (...nextArgs) {
return curried.apply(this, args.concat(nextArgs));
};
}
};
}
这个实现利用了函数的 length 属性来判断还需要多少参数。当收集的参数数量足够时,就执行原函数。
函数组合(Function Composition)是将多个函数连接起来,前一个函数的输出作为下一个函数的输入。数学上表示为:f(g(x))。
在JavaScript中,我们可以从右到左组合函数:
function compose(...fns) {
return function (value) {
return fns.reduceRight((acc, fn) => fn(acc), value);
};
}
也可以从左到右:
function pipe(...fns) {
return function (value) {
return fns.reduce((acc, fn) => fn(acc), value);
};
}
比如有以下简单函数:
const toUpper = str => str.toUpperCase();
const exclaim = str => str + '!';
const greet = str => `Hello, ${str}`;
使用 pipe 组合:
const welcome = pipe(toUpper, exclaim, greet);
welcome('world'); // "Hello, WORLD!"
两者结合使用可以让代码更具表达力和灵活性。
假设我们要处理用户输入:去空格、转大写、添加标签:
const trim = str => str.trim();
const wrap = tag => str => `<${tag}>${str}</${tag}>`;
const transform = pipe(trim, toUpper, wrap('div'));
这里 wrap 是柯里化的,允许我们预配置标签名。这种模式在构建中间件、表单验证或数据转换链时非常有用。
另一个常见场景是条件逻辑的函数化:
const when = predicate => fn => value => predicate(value) ? fn(value) : value; const logIfEven = when(x => x % 2 === 0)(x => console.log(x));
这种风格让逻辑变得可组合、可复用,避免了重复的 if 判断。
基本上就这些。柯里化和组合看似抽象,但在实际开发中能显著提升代码的模块化程度。理解它们的关键在于把函数看作可以传递、组合和配置的“值”。不复杂但容易忽略。
以上就是JavaScript函数柯里化与组合的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号