マッピングされた配列の合計

JavaScriptJavaScriptBeginner
今すぐ練習

This tutorial is from open-source community. Access the source code

💡 このチュートリアルは英語版からAIによって翻訳されています。原文を確認するには、 ここをクリックしてください

はじめに

この実験では、JavaScript におけるマッピングされた配列の合計の概念を探ります。この実験の目的は、提供された関数を使って各要素を値にマッピングすることにより、配列の合計をどのように計算するかを深く理解することです。この実験が終了するまでに、学習者は Array.prototype.map()Array.prototype.reduce() を使って、JavaScript プロジェクトにおいてマッピングされた配列の合計を実装できるようになります。


Skills Graph

%%%%{init: {'theme':'neutral'}}%%%% flowchart RL javascript(("JavaScript")) -.-> javascript/BasicConceptsGroup(["Basic Concepts"]) javascript(("JavaScript")) -.-> javascript/AdvancedConceptsGroup(["Advanced Concepts"]) javascript/BasicConceptsGroup -.-> javascript/variables("Variables") javascript/BasicConceptsGroup -.-> javascript/data_types("Data Types") javascript/BasicConceptsGroup -.-> javascript/arith_ops("Arithmetic Operators") javascript/BasicConceptsGroup -.-> javascript/comp_ops("Comparison Operators") javascript/BasicConceptsGroup -.-> javascript/array_methods("Array Methods") javascript/AdvancedConceptsGroup -.-> javascript/higher_funcs("Higher-Order Functions") javascript/AdvancedConceptsGroup -.-> javascript/destr_assign("Destructuring Assignment") subgraph Lab Skills javascript/variables -.-> lab-28486{{"マッピングされた配列の合計"}} javascript/data_types -.-> lab-28486{{"マッピングされた配列の合計"}} javascript/arith_ops -.-> lab-28486{{"マッピングされた配列の合計"}} javascript/comp_ops -.-> lab-28486{{"マッピングされた配列の合計"}} javascript/array_methods -.-> lab-28486{{"マッピングされた配列の合計"}} javascript/higher_funcs -.-> lab-28486{{"マッピングされた配列の合計"}} javascript/destr_assign -.-> lab-28486{{"マッピングされた配列の合計"}} end

マッピングされた配列要素の合計を計算する関数

提供された関数を使って各要素を値にマッピングすることにより、配列の合計を計算するには、sumBy 関数を使います。この関数は Array.prototype.map() を使って各要素を fn が返す値にマッピングします。その後、Array.prototype.reduce() を使って各値を累積器に加算し、累積器は 0 の値で初期化されます。

const sumBy = (arr, fn) =>
  arr
    .map(typeof fn === "function" ? fn : (val) => val[fn])
    .reduce((acc, val) => acc + val, 0);

使用例:

sumBy([{ n: 4 }, { n: 2 }, { n: 8 }, { n: 6 }], (x) => x.n); // 20 を返す
sumBy([{ n: 4 }, { n: 2 }, { n: 8 }, { n: 6 }], "n"); // 20 を返す

この関数を使ってコーディングを練習するには、ターミナル/SSH を開いて node と入力します。

まとめ

おめでとうございます!あなたはマッピングされた配列の合計の実験を完了しました。あなたのスキルを向上させるために、LabExでさらに多くの実験を練習できます。