js中for in 和 for each in的用法和区别
2017-05-23 09:49
686 查看
转自这里:http://blog.sina.com.cn/s/blog_855dfd9e0101a2w0.html
区别一:
forin是javascript 1.0 中发布的。
for eachin是作为E4X标准的一部分在javascript1.6中发布的,而它不是ECMAScript标准的一部分。
这将意味着存在各种浏览器的兼容性问题。for eachin,对很多浏览器都不支持的。例如是不支持IE6,IE7,IE8等浏览器的。
区别二:
例: var 长方形= {
高:"15",
宽:"25" };
for (var i in 长方形){
alert( i +"," + 长方形[i] );
}
结果依次是: 高,15 ; 宽,25 ;
for each (var i in 长方形){
alert( i +"," + 长方形[i] );
}
结果依次是: 15,undefined ; 25,undefined;
两种遍历方法的变量i的值是不一样的,for eachin无法获得对象的属性名,只能获取到属性值。
最后总结一下使用建议:
(1)遍历普通数组,建议使用原生的遍历方法for,不要贪图方便,因为for in 和foreach in均存在浏览器的兼容问题,不能保证它们对数组的遍历顺序(如果对顺序的不作要求的话,可以使用for in,但本人不建议),有兴趣话,可以阅读的下一篇文章《for
in 的浏览器兼容问题》。
(2)遍历对象,由于for没办法提供理想的遍历,因而只能选择其他方法。这里建议使用for in,从上面讲解的区别,for in比for each 更具优势,for in能获取索引和属性值,而foreach只能获取属性值,而且for each在很多低版本的浏览器是不支持。
for in的兼容性探讨
区别一:
forin是javascript 1.0 中发布的。
for eachin是作为E4X标准的一部分在javascript1.6中发布的,而它不是ECMAScript标准的一部分。
这将意味着存在各种浏览器的兼容性问题。for eachin,对很多浏览器都不支持的。例如是不支持IE6,IE7,IE8等浏览器的。
区别二:
例: var 长方形= {
高:"15",
宽:"25" };
for (var i in 长方形){
alert( i +"," + 长方形[i] );
}
结果依次是: 高,15 ; 宽,25 ;
for each (var i in 长方形){
alert( i +"," + 长方形[i] );
}
结果依次是: 15,undefined ; 25,undefined;
两种遍历方法的变量i的值是不一样的,for eachin无法获得对象的属性名,只能获取到属性值。
最后总结一下使用建议:
(1)遍历普通数组,建议使用原生的遍历方法for,不要贪图方便,因为for in 和foreach in均存在浏览器的兼容问题,不能保证它们对数组的遍历顺序(如果对顺序的不作要求的话,可以使用for in,但本人不建议),有兴趣话,可以阅读的下一篇文章《for
in 的浏览器兼容问题》。
(2)遍历对象,由于for没办法提供理想的遍历,因而只能选择其他方法。这里建议使用for in,从上面讲解的区别,for in比for each 更具优势,for in能获取索引和属性值,而foreach只能获取属性值,而且for each在很多低版本的浏览器是不支持。
for in的兼容性探讨
相关文章推荐
- js中for in 和 for each in的用法和区别
- js中for in 和 for each in的用法和区别
- JS中for与for each in的区别
- 浅谈javascript中for in 和 for each in的区别
- js中关于for循环、for in、foreach、for each in
- as3中for in 和 for each in的区别
- javascript中循环语句 while、do-while、for-in、for用法区别
- for in,for of,for each in ,forEach使用笔记
- javascript 循环语句 while、do-while、for-in、for用法区别
- javascript 循环语句 while、do-while、for-in、for用法区别
- for循环与for in,$('').each 与$.each的区别
- js中数组遍历for与for in区别(强烈建议不要使用for in遍历数组)
- js中使用for 循环和 for in 遍历数组区别
- foreach和for in each 的区别
- js:for in 语句各浏览器有区别
- 从数据结构的角度分析 for each in 比 for in 快的多
- flex: for...in和for...each区别
- js的for..in语句的用法详解
- for each in 用法举例 asp中如何循环取出split中的值
- Flex中的 for in 与 for each in