ホームページ  >  記事  >  ウェブフロントエンド  >  JSのfor…inとfor…ofの違いは何ですか?

JSのfor…inとfor…ofの違いは何ですか?

青灯夜游
青灯夜游転載
2020-12-23 10:48:514844ブラウズ

この記事では、JavaScript の for...in と for...of の違いを紹介します。一定の参考値があるので、困っている友達が参考になれば幸いです。

JSのfor…inとfor…ofの違いは何ですか?

関連する推奨事項: 「JavaScript ビデオ チュートリアル

…向け、および…向け

1 の違い。配列の走査には通常、for ループが使用されます。

ES5 を使用している場合は、 ES5 には、map、filter、some、every、reduce、reduceRight などの配列トラバーサル関数がありますが、返される結果は異なります。ただし、foreach を使用して配列を走査する場合、break を使用してループを中断することはできず、return を使用して外部関数 に戻ることもできません。

Array.prototype.method=function(){
  console.log(this.length);
}
var myArray=[1,2,4,5,6,7]
myArray.name="数组"
for (var index in myArray) {
  console.log(myArray[index]);
}

2. 配列の走査における for の問題

1.index は文字列番号であり、幾何学的操作に直接使用することはできません

2. 走査順序は実際の配列の内部順序に従っていない可能性があります

3. for in を使用すると、プロトタイプを含む配列の列挙可能なすべてのプロパティを走査します。たとえば、Shangli のプロトタイプ メソッドのメソッドと name 属性は

であるため、オブジェクトの走査には for in の方が適しています。配列の走査には for in を使用しないでください。

for ループの使用に加えて、配列をより簡単かつ正確に走査して期待を達成するにはどうすればよいでしょうか (つまり、メソッドと名前を走査することなく)、ES6 の for of はさらに優れています。

Array.prototype.method=function(){
  console.log(this.length);
}
var myArray=[1,2,4,5,6,7]
myArray.name="数组";
for (var value of myArray) {
  console.log(value);
}

for in は配列のインデックス (つまり、キー名) を走査し、for of は配列要素の値を走査することに注意してください。

#for は、配列内の要素のみを走査します。プロトタイプ属性メソッドと配列のインデックス名は含まれません。

3、オブジェクトの走査

オブジェクトの走査は、通常、オブジェクトのキー名を走査するために for in を使用します

Object.prototype.method=function(){
  console.log(this);
}
var myObject={
  a:1,
  b:2,
  c:3
}
for (var key in myObject) {
  console.log(key);
}

for in は、myObject のプロトタイプ メソッド メソッドまで走査できます。プロトタイプ メソッドと For 属性をトラバースしたくない場合は、ループ内で判断できます。

hasOwnPropery メソッドは、プロパティがオブジェクトのインスタンス プロパティであるかどうかを判断できます。

for (var key in myObject) {
  if(myObject.hasOwnProperty(key)){
    console.log(key);
  }
}

ES5 の Object.keys(myObject) を通じて実行することもできます。プロトタイプのメソッドとプロパティを除く、オブジェクトのインスタンス プロパティの配列を取得します。

Object.prototype.method=function(){
  console.log(this);
}
var myObject={
  a:1,
  b:2,
  c:3
}

要約

  • for..of は、数値/配列オブジェクト/文字列/マップ/セットなどの反復子オブジェクトを含むコレクションを走査するのに適していますが、反復子がないためオブジェクトを走査することはできません。 forEach() とは異なり、break、 continue、return ステートメントに正しく応答できます

  • for-of ループは通常のオブジェクトをサポートしませんが、オブジェクトのプロパティを反復したい場合は、オブジェクトの場合は、for-in ループ (これがその役割です) または組み込みの Object.keys() メソッドを使用できます:

  • for (var key of Object.keys(someObject)) {
      console.log(key + ": " + someObject[key]);
    }
  • たとえば、マップ オブジェクトをトラバースするときに構造化を使用するのに適しています。


  • for (var [key, value] of phoneBookMap) {
       console.log(key + "'s phone number is: " + value);
    }
  • myObject.toString() メソッドをオブジェクトに追加するとき、同様に、myObjectSymbol.iterator メソッドを任意のオブジェクトに追加すると、このオブジェクトをトラバースできます。

    たとえば、jQuery を使用しているとします。内部の .each() メソッドはとても気に入っていますが、jQuery オブジェクトでも for-of ループをサポートしたいと考えています。これを行うことができます:

  • jQuery.prototype[Symbol.iterator] = Array.prototype[Symbol.iterator];
Symbol.iterator を持つすべてのオブジェクトは反復可能と呼ばれます。以下の記事では、反復可能オブジェクトの概念が、for-of ループだけでなく、Map コンストラクターや Set コンストラクター、構造化代入、新しいスプレッド演算子など、言語全体でほぼ使用されていることがわかります。

  • for...ofのステップ

    or-of ループは、まずコレクションの Symbol.iterator メソッドを呼び出し、次に新しいイテレータ オブジェクトを返します。イテレータ オブジェクトには、.next() メソッドを持つ任意のオブジェクトを使用できます。for-of ループはこのメソッドをループごとに 1 回繰り返し呼び出します。たとえば、次のコードは私が思いつく最も単純なイテレータです。

  • #
    var zeroesForeverIterator = {
     [Symbol.iterator]: function () {
       return this;
      },
      next: function () {
      return {done: false, value: 0};
     }
    };

Extension

JS 配列走査:

1. 通常の for ループ

var arr = [1,2,0,3,9];
 for ( var i = 0; i <arr.length; i++){
    console.log(arr[i]);
}

2. for の最適化バージョンループ

変数を使用して長さをキャッシュし、長さの繰り返し取得を回避します。配列が大きい場合、最適化効果は明ら​​かです

for(var j = 0,len = arr.length; j < len; j++){
    console.log(arr[j]);
}

3.forEach

ES5 によって導入された、配列に付属するループには、配列を走査するという主な機能があります。実際のパフォーマンスは for よりも劣ります。

arr.forEach(function(value,i){
  console.log(&#39;forEach遍历:&#39;+i+&#39;--&#39;+value);
})

forEach メソッドにも、小さな欠陥: Break ステートメントを使用できない、ループを中断するために return ステートメントを使用して外側の関数に戻ることはできません。

4.map traversal

map は「マッピング」を意味し、その使用法は forEach と似ています。同様に、

break ステートメントは次の目的で使用できません。また、return ステートメントを使用して外部関数に戻ることもできません。

arr.map(function(value,index){
    console.log(&#39;map遍历:&#39;+index+&#39;--&#39;+value);
});

マップ トラバーサルでは、return ステートメントと戻り値の使用がサポートされています

var temp=arr.map(function(val,index){
  console.log(val);  
  return val*val           
})
console.log(temp);

forEach、map都是ECMA5新增数组的方法,所以ie9以下的浏览器还不支持

5.for-of遍历

ES6新增功能

for( let i of arr){
    console.log(i);
}
  • for-of这个方法避开了for-in循环的所有缺陷

  • 与forEach()不同的是,它可以正确响应break、continue和return语句 

for-of循环不仅支持数组,还支持大多数类数组对象,例如DOM NodeList对象。for-of循环也支持字符串遍历

JS对象遍历:

1.for-in遍历

for-in是为遍历对象而设计的,不适用于遍历数组。(遍历数组的缺点:数组的下标index值是数字,for-in遍历的index值"0","1","2"等是字符串)

for-in循环存在缺陷:循环会遍历对象自身的和继承的可枚举属性(不含Symbol属性)

for (var index in arr){
    console.log(arr[index]);
    console.log(index);
}

2.使用Object.keys()遍历

返回一个数组,包括对象自身的(不含继承的)所有可枚举属性(不含Symbol属性).

var obj = {&#39;0&#39;:&#39;a&#39;,&#39;1&#39;:&#39;b&#39;,&#39;2&#39;:&#39;c&#39;};
Object.keys(obj).forEach(function(key){
     console.log(key,obj[key]);
});

3.使用Object.getOwnPropertyNames(obj)遍历

返回一个数组,包含对象自身的所有属性(不含Symbol属性,但是包括不可枚举属性). 

var obj = {&#39;0&#39;:&#39;a&#39;,&#39;1&#39;:&#39;b&#39;,&#39;2&#39;:&#39;c&#39;};
Object.getOwnPropertyNames(obj).forEach(function(key){
    console.log(key,obj[key]);
});

4.使用Reflect.ownKeys(obj)遍历

返回一个数组,包含对象自身的所有属性,不管属性名是Symbol或字符串,也不管是否可枚举.  

var obj = {&#39;0&#39;:&#39;a&#39;,&#39;1&#39;:&#39;b&#39;,&#39;2&#39;:&#39;c&#39;};
Reflect.ownKeys(obj).forEach(function(key){
  console.log(key,obj[key]);
});

更多编程相关知识,请访问:编程入门!!

以上がJSのfor…inとfor…ofの違いは何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はcnblogs.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。