mirror of
https://github.com/toss/es-toolkit.git
synced 2025-01-08 17:31:36 +03:00
3.3 KiB
3.3 KiB
curry
関数をカリー化し、1回に1つのパラメータで呼び出すことができ、次のパラメータを取る新しい関数を返し続けます。 このプロセスはすべてのパラメータが提供されるまで続き、すべてのパラメータが蓄積された段階で元の関数が呼び出されます。
インターフェース
function curry<R>(func: () => R): () => R;
function curry<P, R>(func: (p: P) => R): (p: P) => R;
function curry<P1, P2, R>(func: (p1: P1, p2: P2) => R): (p1: P1) => (p2: P2) => R;
function curry<P1, P2, P3, R>(func: (p1: P1, p2: P2, p3: P3) => R): (p1: P1) => (p2: P2) => (p3: P3) => R;
function curry<P1, P2, P3, P4, R>(
func: (p1: P1, p2: P2, p3: P3, p4: P4) => R
): (p1: P1) => (p2: P2) => (p3: P3) => (p4: P4) => R;
function curry<P1, P2, P3, P4, P5, R>(
func: (p1: P1, p2: P2, p3: P3, p4: P4, p5: P5) => R
): (p1: P1) => (p2: P2) => (p3: P3) => (p4: P4) => (p5: P5) => R;
function curry(func: (...args: any[]) => any): (...args: any[]) => any;
パラメータ
func
((...args: any[]) => any
): カリー化する関数。
戻り値
((...args: any[]) => any
): 1回に1つのパラメータで呼び出すことができるカリー化された関数。
例
function sum(a: number, b: number, c: number) {
return a + b + c;
}
const curriedSum = curry(sum);
// パラメータ `a` に値 `10` を与えます。
const sum10 = curriedSum(10);
// パラメータ `b` に値 `15` を与えます。
const sum25 = sum10(15);
// パラメータ `c` に値 `5` を与えます。
// 関数 'sum' はすべてのパラメータを受け取ったので、今値を返します。
const result = sum25(5);
Lodashとの互換性
es-toolkit/compat
からcurry
をインポートすると、lodashと互換性があります。
インターフェース
function curry(
func: (...args: any[]) => any,
arity: number = func.length,
guard?: unknown
): ((...args: any[]) => any) & { placeholder: typeof curry.placeholder };
namespace curry {
placeholder: symbol;
}
curry
関数は数値arity
をパラメータとして受け取ります。このパラメータは関数が呼び出されるために必要なパラメータの数を指定します。- デフォルト値は関数の
length
プロパティです。arity
が負の値またはNaN
の場合、0
に変換されます。小数点を含む数値の場合は、最も近い整数に切り捨てられます。
- デフォルト値は関数の
funcs.map(curry)
のようにArray#map
関数と簡単に使用できます。- Symbol である
curry.placeholder
の値を使用して、パラメータを部分適用する位置を指定できます。 - 基本の
curry
とは異なり、一度に複数のパラメータを提供できます。残りのパラメータを受け取る新しい関数を返します。
例
import { curry } from 'es-toolkit/compat';
const abc = function (a, b, c) {
return Array.from(arguments);
};
let curried = curry(abc);
curried(1)(2)(3);
// => [1, 2, 3]
curried(1, 2)(3);
// => [1, 2, 3]
curried(1, 2, 3);
// => [1, 2, 3]
// Curried with placeholders.
curried(1)(curry.placeholder, 3)(2);
// => [1, 2, 3]
// Curried with arity.
curried = curry(abc, 2);
curried(1)(2);
// => [1, 2]