配列をオブジェクトにマッピングする

JavaScriptJavaScriptBeginner
今すぐ練習

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

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

はじめに

この実験では、提供されたマッピング関数を使用してオブジェクト配列をオブジェクトにマッピングする方法を探ります。配列をマッピングするために Array.prototype.reduce() メソッドを使用し、結果のオブジェクトのキーと値をそれぞれマッピングするために mapKey 関数と mapValue 関数を使用します。この実験が終了するまでに、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/AdvancedConceptsGroup -.-> javascript/higher_funcs("Higher-Order Functions") javascript/AdvancedConceptsGroup -.-> javascript/destr_assign("Destructuring Assignment") subgraph Lab Skills javascript/variables -.-> lab-28525{{"配列をオブジェクトにマッピングする"}} javascript/data_types -.-> lab-28525{{"配列をオブジェクトにマッピングする"}} javascript/arith_ops -.-> lab-28525{{"配列をオブジェクトにマッピングする"}} javascript/comp_ops -.-> lab-28525{{"配列をオブジェクトにマッピングする"}} javascript/higher_funcs -.-> lab-28525{{"配列をオブジェクトにマッピングする"}} javascript/destr_assign -.-> lab-28525{{"配列をオブジェクトにマッピングする"}} end

JavaScript で配列をオブジェクトにマッピングする方法

JavaScript でオブジェクト配列をオブジェクトにマッピングするには、次の手順に従います。

  1. ターミナル/SSH を開き、コーディングを練習するために node と入力します。
  2. Array.prototype.reduce() を使用して配列をオブジェクトにマッピングします。
  3. mapKey パラメータを使用してオブジェクトのキーをマッピングし、mapValue パラメータを使用して値をマッピングします。

以下は、objectify 関数を使用してオブジェクト配列をオブジェクトにマッピングする方法を示すコード スニペットです。

const objectify = (arr, mapKey, mapValue = (i) => i) =>
  arr.reduce((acc, item) => {
    acc[mapKey(item)] = mapValue(item);
    return acc;
  }, {});

次に、objectify 関数を使用してオブジェクト配列をオブジェクトにマッピングする方法を以下に示します。

const people = [
  { name: "John", age: 42 },
  { name: "Adam", age: 39 }
];

// 名前プロパティをキーとしてオブジェクト配列をオブジェクトにマッピングする
objectify(people, (p) => p.name.toLowerCase());
// 出力: { john: { name: 'John', age: 42 }, adam: { name: 'Adam', age: 39 } }

// 名前プロパティをキーとし、年齢プロパティを値としてオブジェクト配列をオブジェクトにマッピングする
objectify(
  people,
  (p) => p.name.toLowerCase(),
  (p) => p.age
);
// 出力: { john: 42, adam: 39 }

まとめ

おめでとうございます!配列をオブジェクトにマッピングする実験を完了しました。技術力を向上させるために、LabEx でさらに実験を行って練習してください。