JavaScript函数柯里化与组合

22次阅读

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

JavaScript函数柯里化与组合

函数柯里化和组合是函数式编程中的两个核心概念,它们能帮助我们写出更简洁、可复用且易于测试的代码。在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);   }; }

也可以从左到右:

JavaScript函数柯里化与组合

阿里云-虚拟数字人

阿里云-虚拟数字人是什么? …

JavaScript函数柯里化与组合2

查看详情 JavaScript函数柯里化与组合

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 判断。

基本上就这些。柯里化和组合看似抽象,但在实际开发中能显著提升代码的模块化程度。理解它们的关键在于把函数看作可以传递、组合和配置的“值”。不复杂但容易忽略。

text=ZqhQzanResources