ホームページ > ウェブフロントエンド > jsチュートリアル > JavaScript での配列の作成: 包括的なガイド

JavaScript での配列の作成: 包括的なガイド

WBOY
リリース: 2024-07-18 18:23:22
オリジナル
1013 人が閲覧しました

Creating Arrays in JavaScript: A Comprehensive Guide

JavaScript での配列の作成は基本的なタスクですが、経験豊富な開発者でも見落とす可能性のある微妙な点や注意点がいくつかあります。基本を掘り下げて、配列の作成と操作の興味深い側面を探ってみましょう。

基本的な配列の作成

配列を作成する最も簡単な方法は、配列リテラルを使用することです。

let arr = [];
ログイン後にコピー

その後、ループを使用してこの配列にデータを設定できます。

for (let i = 0; i < 5; i++) {
  arr.push(i);
}
ログイン後にコピー

これにより、要素 [0, 1, 2, 3, 4] を含む配列が作成されます。ただし、値を設定せずに空の配列を作成すると、項目も空のスロットも含まれない配列が作成されます。

配列コンストラクターの使用

配列を作成する別の方法は、Array コンストラクターを使用することです。

let arr = Array(5);
ログイン後にコピー

単一の数値引数が渡されると、指定された長さを持つスパース配列が作成されますが、実際の要素は作成されません。

console.log(arr.length); // 5
console.log(arr); // [empty × 5]
ログイン後にコピー

スパース配列

疎配列には「空のスロット」があり、map、filter、forEach などのメソッドを使用するときに予期しない動作が発生する可能性があります。これらのメソッドは空のスロットをスキップします:

let arr = Array(5);
arr = arr.map((x, i) => i); // Still [empty × 5]
ログイン後にコピー

このような配列に値を設定するには、値を手動で設定する必要があります。

arr[0] = 2;
arr[4] = 3;
console.log(arr); // [2, empty × 3, 3]
ログイン後にコピー

スパース配列の処理

スパース配列を効果的に処理するには、fill などのメソッドを使用して値を初期化できます。

let arr = Array(5).fill(1);
console.log(arr); // [1, 1, 1, 1, 1]
ログイン後にコピー

ただし、オブジェクトまたは配列を入力する場合は注意してください:

let arr = Array(5).fill({});
arr[0].name = 'John';
console.log(arr); // [{name: 'John'}, {name: 'John'}, {name: 'John'}, {name: 'John'}, {name: 'John'}]
ログイン後にコピー

各要素は同じオブジェクトを参照します。これを回避するには、map:
を使用します。

let arr = Array(5).fill(0).map(() => ({}));
arr[0].name = 'John';
console.log(arr); // [{name: 'John'}, {}, {}, {}, {}]
ログイン後にコピー

Array.from メソッド

Array.from は、配列のようなオブジェクトまたは反復可能なオブジェクトから配列を作成する多用途の方法を提供します。

let arr = Array.from({ length: 5 }, (_, i) => i);
console.log(arr); // [0, 1, 2, 3, 4]
ログイン後にコピー

このメソッドは、2 次元配列を作成する場合にも役立ちます:

let arr2D = Array.from({ length: 5 }, () => Array(5).fill(0));
arr2D[0][0] = 1;
console.log(arr2D); // [[1, 0, 0, 0, 0], [0, 0, 0, 0, 0], [0, 0, 0, 0, 0], [0, 0, 0, 0, 0], [0, 0, 0, 0, 0]]
ログイン後にコピー

配列の反復処理

JavaScript には、配列を反復処理するためのいくつかの方法があり、それぞれが疎配列を異なる方法で処理します。

  • for ループ: 空のスロットを未定義として扱い、すべてのインデックスを処理します。
  • for...in: 空のスロットをスキップして、配列のインデックスを反復処理します。
  • for...of: 空のスロットを未定義として扱い、値を反復処理します。

結論

JavaScript での配列の作成と操作の複雑さを理解すると、よくある落とし穴を回避し、より効率的なコードを作成するのに役立ちます。配列リテラル、Array コンストラクター、または Array.from や fill などのメソッドを使用しているかどうかに関係なく、これらのツールがどのように機能するかを知ることで、プロジェクト内で配列を効果的に処理できるようになります。

このガイドが役に立ったと思われた場合は、お知らせください。私は、JavaScript の基本をさらに掘り下げたコンテンツを作成したいと常に思っています。読んでいただきありがとうございます。コーディングを楽しんでください!

以上がJavaScript での配列の作成: 包括的なガイドの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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