Я пытаюсь понять композицию и концепцию «секвенирования» в Javascript с помощью упражнения:
Def. "состав" compose(f,g)(x) = f(g(x))
Def. "последовательность" sequence(f,g)(x) = g(f(x))
для большего количества аргументов sequence(f,g)(...args) = g(f(...args))
const sequence2 = (f1, f2) => (...args) => f2( f1(...args) );
const sequence = (f1, ...fRest) => fRest.reduce(sequence2, f1);
const f1 = (a, b) => {
console.log(`[f1] working on: ${a} and ${b}`);
return a + b;
}
const f2 = a => `Result is ${a}`;
const sequenceResult = sequence(f1, f1, f2)(1, 2, 5);
console.log(sequenceResult);
Консоль показывает:
[f1] working on: 1 and 2
[f1] working on: 3 and undefined
Result is NaN
Кажется, что вторая функция в последовательности может получить доступ к аргументам: что-то мне не хватает или это неправильный подход к работе с параметрами? (Функция последовательности работает для функций без параметров).
Здесь JSFiddle