ホームページ > 記事 > ウェブフロントエンド > JSのfor…inとfor…ofの違いは何ですか?
この記事では、JavaScript の 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 (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); }
たとえば、jQuery を使用しているとします。内部の .each() メソッドはとても気に入っていますが、jQuery オブジェクトでも for-of ループをサポートしたいと考えています。これを行うことができます:
jQuery.prototype[Symbol.iterator] = Array.prototype[Symbol.iterator];Symbol.iterator を持つすべてのオブジェクトは反復可能と呼ばれます。以下の記事では、反復可能オブジェクトの概念が、for-of ループだけでなく、Map コンストラクターや Set コンストラクター、構造化代入、新しいスプレッド演算子など、言語全体でほぼ使用されていることがわかります。
or-of ループは、まずコレクションの Symbol.iterator メソッドを呼び出し、次に新しいイテレータ オブジェクトを返します。イテレータ オブジェクトには、.next() メソッドを持つ任意のオブジェクトを使用できます。for-of ループはこのメソッドをループごとに 1 回繰り返し呼び出します。たとえば、次のコードは私が思いつく最も単純なイテレータです。
var zeroesForeverIterator = { [Symbol.iterator]: function () { return this; }, next: function () { return {done: false, value: 0}; } };
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('forEach遍历:'+i+'--'+value); })
forEach メソッドにも、小さな欠陥: Break ステートメントを使用できない、ループを中断するために return ステートメントを使用して外側の関数に戻ることはできません。
4.map traversal
map は「マッピング」を意味し、その使用法は forEach と似ています。同様に、break ステートメントは次の目的で使用できません。また、return ステートメントを使用して外部関数に戻ることもできません。
arr.map(function(value,index){ console.log('map遍历:'+index+'--'+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 = {'0':'a','1':'b','2':'c'}; Object.keys(obj).forEach(function(key){ console.log(key,obj[key]); });
3.使用Object.getOwnPropertyNames(obj)遍历
返回一个数组,包含对象自身的所有属性(不含Symbol属性,但是包括不可枚举属性).
var obj = {'0':'a','1':'b','2':'c'}; Object.getOwnPropertyNames(obj).forEach(function(key){ console.log(key,obj[key]); });
4.使用Reflect.ownKeys(obj)遍历
返回一个数组,包含对象自身的所有属性,不管属性名是Symbol或字符串,也不管是否可枚举.
var obj = {'0':'a','1':'b','2':'c'}; Reflect.ownKeys(obj).forEach(function(key){ console.log(key,obj[key]); });
更多编程相关知识,请访问:编程入门!!
以上がJSのfor…inとfor…ofの違いは何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。