Skip to content

partial

一部の引数を事前に適用した新しい関数を作成します。

typescript
const partialFunc = partial(func, arg1, arg2);

参照

partial(func, ...args)

関数の一部の引数を事前に固定したいときにpartialを使用してください。事前に提供された引数が関数の前方に配置され、後で渡される引数は後方に追加されます。

関数型プログラミングでよく使用されるカリー化(currying)と似た概念です。bindとは異なりthisコンテキストを固定しません。

partial.placeholderを使用すると特定の位置の引数を後で渡すことができます。

typescript
import { partial } from 'es-toolkit/function';

// 基本的な使用法
function greet(greeting: string, name: string) {
  return `${greeting}, ${name}!`;
}

const sayHello = partial(greet, 'Hello');
console.log(sayHello('John')); // 'Hello, John!'
console.log(sayHello('Jane')); // 'Hello, Jane!'

// 複数の引数を適用
function multiply(a: number, b: number, c: number) {
  return a * b * c;
}

const double = partial(multiply, 2);
console.log(double(3, 4)); // 24

const doubleAndTriple = partial(multiply, 2, 3);
console.log(doubleAndTriple(4)); // 24

プレースホルダーを使用して引数の順序を調整できます。

typescript
import { partial } from 'es-toolkit/function';

function subtract(a: number, b: number, c: number) {
  return a - b - c;
}

// 2番目の引数のみ固定し、1番目と3番目は後で渡す
const subtractFrom5 = partial(subtract, partial.placeholder, 5, partial.placeholder);
console.log(subtractFrom5(10, 2)); // 10 - 5 - 2 = 3

// 配列メソッドと一緒に使用
const numbers = [1, 2, 3, 4, 5];
const addTen = partial((x: number, y: number) => x + y, 10);
const result = numbers.map(addTen);
console.log(result); // [11, 12, 13, 14, 15]

パラメータ

  • func (F): 引数を部分的に適用する関数です。
  • args (any[], 選択): 事前に適用する引数です。

戻り値

((...args: any[]) => ReturnType<F>): 一部の引数が事前に適用された新しい関数を返します。

MIT ライセンスの下で配布されています。