オブジェクトのキーをマッピングする

JavaScriptJavaScriptBeginner
今すぐ練習

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

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

はじめに

この実験では、与えられた関数を使ってオブジェクトのキーをマッピングし、新しいオブジェクトを生成する方法を探ります。オブジェクトのキーを反復処理するために Object.keys() を使い、与えられた関数を使って同じ値とマッピングされたキーを持つ新しいオブジェクトを作成するために 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-28480{{"オブジェクトのキーをマッピングする"}} javascript/data_types -.-> lab-28480{{"オブジェクトのキーをマッピングする"}} javascript/arith_ops -.-> lab-28480{{"オブジェクトのキーをマッピングする"}} javascript/comp_ops -.-> lab-28480{{"オブジェクトのキーをマッピングする"}} javascript/array_methods -.-> lab-28480{{"オブジェクトのキーをマッピングする"}} javascript/higher_funcs -.-> lab-28480{{"オブジェクトのキーをマッピングする"}} javascript/destr_assign -.-> lab-28480{{"オブジェクトのキーをマッピングする"}} end

オブジェクトのキーをマッピングする関数

与えられた関数を使ってオブジェクトのキーをマッピングし、新しいオブジェクトを生成するには、次の手順に従います。

  1. ターミナル/SSH を開き、コーディングの練習を始めるために node と入力します。
  2. Object.keys() を使ってオブジェクトのキーを反復処理します。
  3. Array.prototype.reduce() を使って、与えられた関数 (fn) を使って同じ値とマッピングされたキーを持つ新しいオブジェクトを作成します。

以下は、mapKeys 関数の例の実装です。

const mapKeys = (obj, fn) =>
  Object.keys(obj).reduce((acc, k) => {
    acc[fn(obj[k], k, obj)] = obj[k];
    return acc;
  }, {});

この関数を次のような例の入力でテストすることができます。

mapKeys({ a: 1, b: 2 }, (val, key) => key + val); // { a1: 1, b2: 2 }

まとめ

おめでとうございます!あなたはオブジェクトのキーをマッピングする実験を完了しました。あなたの技術を向上させるために、LabExでさらに多くの実験を練習することができます。