JavaScript ステートメントの一般的な for ループの詳細な説明

JavaScript ステートメントの一般的な for ループの詳細な説明

JavaScript には、for、for in、for of、forEach ループなど、多くのループ ステートメントがあります。今日は、Array、Object、Set (ES6)、Map (ES6) の 4 つのデータ構造のループ ステートメントのサポートと違いを比較します。

4つの新しいテストデータタイプを作成する

arr = [1, 2, 3, 4, 5, 6]とします。
obj = { a: 1, b: 2, c: 3 } とします。
map = new Map([['a', 'a1'], ['b', 'b2'], ['c', 'c3']]);
set = new Set(['a', 'b', 'c']);

1 対

通常の for ループは配列でも使用できます。 配列を走査する場合、配列の添字インデックスを走査し、添字を通じて値を取得します。

for (let i = 0; i < arr.length; i++) { // i は添え字(インデックス)
  コンソールログ(i)
  コンソールログ(arr[i])
}

2 で

for in は配列とオブジェクトの両方で使用できます。プロトタイプのプロパティもループアウトされることに注意してください。

配列

arr = [1, 2, 3, 4, 5, 6]とします。
配列.プロトタイプ.a = "1"

for (let i in arr) { // i は添え字(インデックス)
  コンソールログ(i)
  コンソールログ(arr[i])
}

プロトタイプもループアウトされていることがわかりますが、これは必要なことではありません。hasOwnProperty を使用してプロトタイプのプロパティをフィルター処理できます。

arr = [1, 2, 3, 4, 5, 6]とします。
配列.プロトタイプ.a = "1"

for (let i in arr) { // i は添え字(インデックス)
  もし(arr.hasOwnProperty(i)) {
    コンソールログ(i)
    コンソールログ(arr[i])
  }
}

物体

obj = { a: 1, b: '2', c: 3 } とします。
オブジェクト.プロトタイプ.d = 4

for (let key in obj) { // keyはキーです console.log(key)
  console.log(obj[キー])
}

Object にも同じ問題があります。プロトタイプ プロパティもループされ、プロトタイプのプロパティも hasOwnProperty を通じてフィルター処理されます。

for (let key in obj) { // key はキーです if (obj.hasOwnProperty(key)) {
    console.log(キー)
    console.log(obj[キー])
  }
}

3 の

for of は、Array、Object、Set、Map で使用できます。

配列

配列は本質的にオブジェクトなので、暗黙のプロトタイプ (__proto__) で定義されたメソッドを見つけることができます。

for (let key of arr.keys()) { // keyは添え字です console.log(key)
}
for (let value of arr) { // valueは値です console.log(value)
}
for (let value of arr.values()) { // valueは値です console.log(value)
}
for (let [key, value] of arr.entries()) { // キーは添え字、値は値、console.log(key,value)
}

物体

for (let [key, value] of Object.entries(obj)) { // キーは添え字、値は値、console.log(key, value)
}

セット

Setには重複がないので、キーと値は一貫しており、次の4つの出力は一貫していることを意味します。

for (let key of set.keys()) {  
  console.log(キー)
}
for (let 値のセット) {     
  console.log(値)
}
for (let 値 set.values()) { 
  console.log(値)
}
for (let [キー, 値] of set.entries()) { 
  console.log(キー、値)
}

地図

(map.keys() のキーを取得) { 
  console.log(キー)
}
for (マップの値) {     
  console.log(値)
}
for (map.values() の値を取得) { 
  console.log(値)
}
map.entries() の (let [キー, 値]) { 
  console.log(キー、値)
}

ループから抜け出すには break および continue ステートメントを使用し、関数本体から戻るには return を使用します。

for (let key of arr.keys()) { // キーは添え字です if (key == 3) {
    戻る
  }
  console.log(キー)
}
for (let key of arr.keys()) { // キーは添え字です if (key == 3) {
    壊す
  }
  console.log(キー)
}
for (let key of arr.keys()) { // キーは添え字です if (key == 3) {
    続く
  }
  console.log(キー)
}

4 それぞれ

forEach ループは、Array、Set、Map で使用できます。ただし、このメソッドでは、break または continue ステートメントを使用してループから抜け出すことも、return を使用して関数本体から戻ることもできません。

配列

arr.forEach((値、インデックス) => {
  console.log(値、インデックス)
})

セット

set.forEach((値、キー) => {
  console.log(値、キー)
})

地図

map.forEach((値、キー) => {
  console.log(値、キー)
})

中断、継続、戻る

プロンプトを表示するには続行を使用します

不正な継続ステートメント: 周囲の反復ステートメントがありません

breakを使用すると

不正なbreak文

returnを使用すると、戻らずにループが継続されます。

5 結論

通常の for ループは配列でも使用できます。配列を走査する場合、配列の添字インデックスを走査し、添字を通じて値を取得します。 for in は配列とオブジェクトの両方で使用できます。ただし、プロトタイプのプロパティもループアウトされることに注意してください。for と of は、Array、Object、Set、Map で使用できます。 break、continue、return も使用できます。forEach ループは、Array、Set、Map で使用できます。ただし、このメソッドでは、break または continue ステートメントを使用してループから抜け出すことも、return を使用して関数本体から戻ることもできません。

JavaScript 文でよく使われる for ループの詳しい説明はこれで終わりです。js for ループに関するその他の関連コンテンツについては、123WORDPRESS.COM の過去の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • JavaScript における 3 つの for ループ ステートメントの使用の概要 (for、for...in、for...of)
  • JavaScript ではおそらく switch 文を使う必要はない
  • JavaScript の条件文の最適化手法の概要
  • Pythonでjsステートメントを実行する方法
  • JavaScriptステートメントを理解するのに役立つ記事

<<:  Win2008 R2 mysql 5.5 zip 形式 mysql のインストールと設定

>>:  nginx プロキシでの複数の 302 応答の解決策 (nginx Follow 302)

推薦する

WeChatアプレットの世界的な状況の詳細な説明

序文WeChat アプレットでは、App.js の globalData を中間ブリッジとして使用し...

MySQL でデータベースを作成した後、ユーザー 'root'@'%' によるデータベース 'xxx' へのアクセスが拒否される問題を解決する

序文最近、仕事で問題が発生しました。データベースを作成した後、データベースに接続するときにエラーが発...

Alibaba Cloud ECS サーバーの開始プロセス (初心者必読のチュートリアル)

1. Alibaba Cloudは、個人のニーズに応じて適切なクラウドサーバーを選択し、CPU、メ...

Alibaba Cloud ECS サーバーでポート 8080 を開く方法

セキュリティ上の理由から、Alibaba Cloud Server ECS にはデフォルトで独自のセ...

SQL Server での exists と except の使用法の概要

目次1. 存在する1.1 説明1.2 例1.3 交差/2017-07-21 2. 除く2.1 説明2...

CSS3アニメーションを使用した簡単な指クリックアニメーションの実装例

この記事では主に、CSS3 アニメーションで簡単な指クリックアニメーションを実装する例を紹介し、皆さ...

Linux ファイアウォールを設定してポート 80 と 3306 を開く方法

ポート80も設定されています。まずファイアウォール設定ファイルを入力しますシェル># vim ...

MySQLの起動失敗の解決策

MySQLの起動失敗の解決策MySQLを起動できませんmysqlを停止した後、いくつかの操作(ホスト...

MySQL の垂直テーブルを水平テーブルに変換する方法と最適化のチュートリアル

1. 縦型テーブルと横型テーブル垂直テーブル: テーブル内のフィールドとフィールド値はキーと値の形式...

MySQL の隠し列の詳細表示

目次1. 主キーが存在する2. 主キーはないが、一意のインデックスが存在する3. 共同主キーまたは共...

Net Core実装プロセス分析のDoc​​kerインストールと展開

1. Dockerのインストールと設定 #CentOS をインストールし、Docker パッケージを...

Tcl言語に基づくシンプルなネットワーク環境を構成するプロセスの分析

1. Tclスクリプトファイルcircle.tclコードコメント #シミュレーションに必要なプロパテ...

MySQL のテーブルリターンとインデックスカバレッジの例の詳細な説明

目次インデックスタイプインデックス構造非クラスター化インデックスクエリインデックスカバー要約するイン...

CSSを使用して円形の波効果を実現する

モバイル デバイスでは、金額を表示するために円形の波グラフィックがよく使用されます。最初は、この効果...

記事では、js を使用して弾幕効果を実現する方法を説明します

目次新しい HTML ファイルを作成します。初期テンプレートを作成するHTML の追加CSS パディ...