私は最近、JavaScript の Array オブジェクトを反復するさまざまな方法を尋ねる面接の質問に遭遇しました。いくつかのコード スニペットの例を提供することが期待されていたため、プロンプトは最初は単純そうに見えました。しかし、この質問に興味をそそられたので、各メソッドをもう少し深く掘り下げて、その使用方法だけでなく、あるアプローチを別のアプローチより選択する場合とその理由についても検討することにしました。
この記事では、JavaScript で配列を反復処理するさまざまな方法を説明し、その違い、利点、使用例を強調します。
for ループ
利点:
for...of ループが導入される前は、従来の for ループが配列反復の標準的な方法でした。ただし、インデックスを 0 ではなく 1 から開始したり、arr.length - 1 の代わりに誤って arr.length を使用したりするなど、エラーが発生しやすい可能性があります。MDN が示唆しているように、「通常は... に使用するのが最善です」できれば。"
いつ使用するか:
反復をスキップしたり、逆に反復したりするなど、反復を完全に制御する必要がある場合。
反復中にインデックスと値の両方が必要な場合。
の...
利点:
いつ使用するか:
値を操作するだけでよく、インデックスにアクセスする必要がない場合。
Array.prototype.map()
利点:
いつ使用するか:
配列の各要素に関数を適用し、その結果を新しい配列として必要とする場合。
Array.prototype.forEach()
利点:
いつ使用するか:
配列の各要素に関数を適用したいが、新しい配列を返す必要がない場合。
Array.prototype.entries()
利点:
いつ使用するか:
配列要素のインデックスと値の両方にアクセスする必要がある場合。
Array.prototype.keys()
利点:
いつ使用するか:
配列要素のインデックスのみを提供する反復子が必要な場合。
Array.prototype.values()
利点:
いつ使用するか:
配列要素の値のみを提供する反復子が必要な場合。
配列反復子とは:
Array.prototype.entries()、Array.prototype.keys()、および Array.prototype.values() は、新しい配列反復子オブジェクトを返します。これらの反復子を使用すると、配列のようなコレクションを一度に 1 要素ずつ走査できます。これらには、シーケンス内の次の値を提供する next() メソッドが付属しており、必要に応じて呼び出すことができ、メモリの節約に役立ちます。
entrys() を使用した例を次に示します:
const arr = ['a', 'b', 'c']; const iterator = arr.entries(); console.log(iterator.next()); // { value: [0, 'a'], done: false } console.log(iterator.next()); // { value: [1, 'b'], done: false } console.log(iterator.next()); // { value: [2, 'c'], done: false } console.log(iterator.next()); // { value: undefined, done: true }
正直に言うと、私はこれらの手法の詳細や用途について十分に理解していなかったので、この面接の質問に取り組み、理解を深めたことは非常に重要でした。基本的なループを使用している場合でも、より高度な関数型プログラミング手法を使用している場合でも、これらの方法を知っていれば、コードの効率と読みやすさを大幅に向上させることができます。
以上がJavaScript 配列の反復メソッドを理解するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。