ホームページ > ウェブフロントエンド > jsチュートリアル > 「map()」を使用すると「new Array(count)」が配列リテラルと異なる動作をするのはなぜですか?

「map()」を使用すると「new Array(count)」が配列リテラルと異なる動作をするのはなぜですか?

DDD
リリース: 2024-12-13 11:53:13
オリジナル
136 人が閲覧しました

Why Does `new Array(count)` Behave Differently from Array Literals When Using `map()`?

配列の作成が配列の変換に影響するのはなぜですか?

特定の環境では、new Array(count) を使用して配列を作成すると、予期しない動作が発生します。マップメソッド。リテラル構文で作成された配列 (例: [未定義、未定義、未定義]) とは異なり、new Array(3) で構築された配列は、map を使用して要素を正しく変換しません。

この動作は、埋められていない配列に起因します。 new Array(count) を使用して配列を作成すると、結果の配列の要素は未定義のままになります。これは、要素を未定義で自動的に初期化するリテラル構文を使用して作成された配列とは異なります。

この問題を回避し、マップが正しく動作することを確認するには、配列要素に未定義などの任意の値を入力することをお勧めします。 、変換を試みる前に。 Array.prototype.fill() メソッドは、この目的に使用できます。

たとえば、new Array(count) とマップを使用して最初の 10 個の整数の配列を作成するには:

let arr = new Array(10).fill(undefined).map((val, idx) => idx);
ログイン後にコピー

これにより、目的の出力が生成されます:

[0,1,2,3,4,5,6,7,8,9]
ログイン後にコピー

以上が「map()」を使用すると「new Array(count)」が配列リテラルと異なる動作をするのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート