freeCodeCamp/curriculum/challenges/japanese/02-javascript-algorithms-an.../functional-programming/understand-functional-progr...

4.3 KiB

id title challengeType forumTopicId dashedName
587d7b8e367417b2b2512b5c 関数型プログラミングの用語を理解する 1 301240 understand-functional-programming-terminology

--description--

FCC のチームの気が変わって、今は緑茶と紅茶の 2 種類のお茶が欲しくなりました。 クライアントの気が変わるというのは一般的な事実としてよくあることです。

そんな情報を踏まえて、前回のチャレンジで取り上げた getTea 関数を見直して、さまざまなお茶のリクエストを処理する必要が出てきました。 パラメーターとして関数を受け取るように getTea を変更して、用意するお茶の種類を変えることができます。 これで getTea の柔軟性が増し、クライアントのリクエストが変更されたときにプログラマーはより詳細に制御できるようになります。

ですがその前に、関数型に関する用語をいくつか説明しておきましょう。

ある関数の呼び出しを決定するために挿入されたり渡されたりする関数のことを、コールバックと呼びます。 たとえば filter などの他のメソッドにコールバック関数を渡す例を紹介しました。この場合は、フィルターで配列を絞り込むための条件を JavaScript に指示します。

変数に割り当てることができる関数、別の関数に渡すことができる関数、または別の関数から他の通常の値とまったく同じように返すことができる関数のことを、第一級関数と呼びます。 JavaScript の関数はすべて第一級関数です。

引数として関数を受け取る関数、または戻り値として関数を返す関数のことを、高階関数と呼びます。

関数が他の関数に渡されたり、他の関数から返されたりする場合、それらの受け渡しされる関数のことをラムダと呼ぶことがあります。

--instructions--

緑茶を 27 杯分、紅茶を 13 杯分用意し、それぞれ tea4GreenTeamFCCtea4BlackTeamFCC という変数に保存してください。 getTea 関数を変更したので、最初の引数として関数を取ることに注意してください。

注: データ (お茶のカップ数) は最後の引数として渡します。 これについてはこのあとのレッスンで詳しく説明します。

--hints--

tea4GreenTeamFCC 変数は、チーム用に 27 杯分の緑茶を保持する必要があります。

assert(tea4GreenTeamFCC.length === 27);

tea4GreenTeamFCC 変数は、緑茶のカップを保持する必要があります。

assert(tea4GreenTeamFCC[0] === 'greenTea');

tea4BlackTeamFCC 変数は、13 杯分の紅茶を保持する必要があります。

assert(tea4BlackTeamFCC.length === 13);

tea4BlackTeamFCC 変数は、紅茶のカップを保持する必要があります。

assert(tea4BlackTeamFCC[0] === 'blackTea');

--seed--

--seed-contents--

// Function that returns a string representing a cup of green tea
const prepareGreenTea = () => 'greenTea';

// Function that returns a string representing a cup of black tea
const prepareBlackTea = () => 'blackTea';

/*
Given a function (representing the tea type) and number of cups needed, the
following function returns an array of strings (each representing a cup of
a specific type of tea).
*/
const getTea = (prepareTea, numOfCups) => {
  const teaCups = [];

  for(let cups = 1; cups <= numOfCups; cups += 1) {
    const teaCup = prepareTea();
    teaCups.push(teaCup);
  }
  return teaCups;
};

// Only change code below this line
const tea4GreenTeamFCC = null;
const tea4BlackTeamFCC = null;
// Only change code above this line

console.log(
  tea4GreenTeamFCC,
  tea4BlackTeamFCC
);

--solutions--

const prepareGreenTea = () => 'greenTea';
const prepareBlackTea = () => 'blackTea';

const getTea = (prepareTea, numOfCups) => {
  const teaCups = [];

  for(let cups = 1; cups <= numOfCups; cups += 1) {
    const teaCup = prepareTea();
    teaCups.push(teaCup);
  }
  return teaCups;
};

const tea4BlackTeamFCC = getTea(prepareBlackTea, 13);
const tea4GreenTeamFCC = getTea(prepareGreenTea, 27);