es-toolkit/docs/ja/reference/function/flowRight.md
2024-10-03 18:04:32 +09:00

2.2 KiB

flowRight

右から左に順番に与えられた関数を実行する新しい関数を作成します。前の関数の戻り値が次の関数への引数として渡されます。

戻り関数のthisコンテキストも、パラメーターとして提供された関数に渡されます。

このメソッドはflowのようですが、右から左に与えられた関数を呼び出す関数を作成する点が異なります。

インターフェース

function flowRight<R>(f: () => R): () => R;
function flowRight<A extends any[], R>(f1: (...args: A) => R): (...args: A) => R;
function flowRight<A extends any[], R1, R2>(f2: (a: R1) => R2, f1: (...args: A) => R1): (...args: A) => R2;
function flowRight<A extends any[], R1, R2, R3>(
  f3: (a: R2) => R3,
  f2: (a: R1) => R2,
  f1: (...args: A) => R1
): (...args: A) => R3;
function flowRight<A extends any[], R1, R2, R3, R4>(
  f4: (a: R3) => R4,
  f3: (a: R2) => R3,
  f2: (a: R1) => R2,
  f1: (...args: A) => R1
): (...args: A) => R4;
function flowRight<A extends any[], R1, R2, R3, R4, R5>(
  f5: (a: R4) => R5,
  f4: (a: R3) => R4,
  f3: (a: R2) => R3,
  f2: (a: R1) => R2,
  f1: (...args: A) => R1
): (...args: A) => R5;
function flowRight(...funcs: Array<(...args: any[]) => any>): (...args: any[]) => any;

パラメータ

  • funcs ((...args: any[]) => any): 呼び出す関数。

戻り値

((...args: any[]) => any): 新しい合成関数。

const add = (x: number, y: number) => x + y;
const square = (n: number) => n * n;

const combined = flowRight(square, add);
console.log(combined(1, 2)); // 9

Lodash 互換性

es-toolkit/compat から flowRight をインポートすると、Lodash と互換になります。

  • flowRight は関数の配列と個別の関数の両方を引数として受け入れます。
  • 提供された関数が関数でない場合、flowRight はエラーをスローします。
import { flowRight } from 'es-toolkit/compat';

const add = (x: number, y: number) => x + y;
const square = (n: number) => n * n;
const double = (n: number) => n * 2;

const combined = flowRight(double, [square, add]);
console.log(combined(1, 2)); // => 18