Skip to content

flowRight

주어진 함수들을 오른쪽에서 왼쪽으로 순서대로 실행하는 새로운 함수를 생성해요. 이전 함수의 결괏값은 다음 함수의 파라미터로 주어져요.

반환된 함수에게 주어진 this는 파라미터로 주어진 함수들에게도 전달돼요.

이 메서드는 flow와 비슷하지만, 주어진 함수들을 오른쪽에서 왼쪽으로 호출하는 함수를 생성해요.

인터페이스

typescript
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): 주어진 함수들을 오른쪽에서 왼쪽으로 순서대로 실행하는 새로운 함수.

예시

typescript
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 는 오류를 발생시켜요.
typescript
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

MIT 라이선스에 따라 배포됩니다.