今回は、Map と ForEach の使用の違いと、Map と ForEach を使用する際の 注意事項 についてお届けします。実際のケースを見てみましょう。
すでに JavaScript の経験がある場合は、おそらく同じように見える 2 つのメソッド、Array.prototype.map() と Array.prototype.forEach() をすでにご存知でしょう。 では、それらの違いは何ですか?
定義
forEach(): 提供された関数を配列要素ごとに 1 回実行します。
map(): 呼び出し元の配列のすべての要素に対して指定された関数を呼び出した結果を含む新しい配列を作成します。
違いは何ですか? forEach() メソッドは実行結果を返しませんが、未定義です。つまり、forEach() は元の配列を変更します。 map() メソッドは新しい配列を取得して返します。
例
let arr = [1, 2, 3, 4, 5];
forEach は意味のある値を返さないことに注意してください。
コールバック関数
内の arr の値を直接変更します。arr.forEach((num, index) => { return arr[index] = num * 2; });
// arr = [2, 4, 6, 8, 10]
Map
let doubled = arr.map(num => { return num * 2; });
// doubled = [2, 4, 6, 8, 10]
実行速度の比較
jsPrefは、さまざまなJavaScriptの実行速度を比較するのに非常に優れたWebサイトです。機能。
forEach()とmap()のテスト結果は次のとおりです:私のコンピュータでのforEach()の実行速度はmap()よりも70%遅いことがわかります。ブラウザの実行結果は人それぞれ異なります。次のリンクを使用してテストできます: Map vs. forEach - jsPref。
JavaScript は非常に柔軟なので、バグがあるかどうかわからないほど、オンラインでリアルタイム監視するために Fundebug に接続することもできます。 関数の観点から理解するプログラミングで関数を使用する
ことに慣れているなら、間違いなく map() を使いたくなるでしょう。 forEach() は元の配列の値を変更し、map() は新しい配列を返すため、元の配列は影響を受けません。 何をしたいかによる。 forEach は、データを変更する予定はないが、データベースに保存したり印刷したりするなど、データを使用して何かをしたい場合に適しています。let arr = ['a', 'b', 'c', 'd']; arr.forEach((letter) => { console.log(letter); }); // a // b // c // d
position
) (map()、filter()、reduce() などを組み合わせて) を使用して、より多くのトリックを実行できることです。let arr = [1, 2, 3, 4, 5]; let arr2 = arr.map(num => num * 2).filter(num => num > 5); // arr2 = [6, 8, 10]
画像がロードされる前にローディングサークルを表示する効果
以上がMap と ForEach の使用の違いの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。