js中的for in和for each in的用法和区别

区别一:javascript

for in是javascript 1.0 中发布的。
for each in是做为E4X标准的一部分在javascript 1.6中发布的,而它不是ECMAScript标准的一部分。
这将意味着存在各类浏览器的兼容性问题。for each in,对不少浏览器都不支持的。例如是不支持IE6,IE7,IE8等浏览器的。

区别二:java

例: var 长方形= { 高:"15", 宽:"25" };数组

for (var i in 长方形){浏览器

alert( i + "," + 长方形[i] );

}
结果依次是: 高,15 ; 宽,25 ;code

for each (var i in 长方形){对象

alert( i + "," + 长方形[i] );

}
结果依次是: 15, undefined ; 25, undefined;索引

两种遍历方法的变量i的值是不同的,for each in没法得到对象的属性名,只能获取到属性值。ip

最后总结一下使用建议:变量

(1)遍历普通数组,建议使用原生的遍历方法for,不要贪图方便,由于for in 和for each in均存在浏览器的兼容问题,不能保证它们对数组的遍历顺序(若是对顺序的不做要求的话,能够使用for in ,但本人不建议),有兴趣话,能够阅读的下一篇文章《for in 的浏览器兼容问题》。兼容性

(2)遍历对象,因为for没办法提供理想的遍历,于是只能选择其余方法。这里建议使用for in ,从上面讲解的区别,for in比for each 更具优点,for in能获取索引和属性值,而for each只能获取属性值,并且for each在不少低版本的浏览器是不支持。

相关文章
相关标签/搜索