html5中文学习网

您的位置: 首页 > 网站及特效实例 > javascript特效 » 正文

浅谈javascript中for in 和 for each in的区别_javascript技巧_

[ ] 已经帮助:人解决问题

区别一:XqRHTML5中文学习网 - HTML5先行者学习网

        for in是javascript 1.0 中发布的。XqRHTML5中文学习网 - HTML5先行者学习网
        for each in是作为E4X标准的一部分在javascript 1.6中发布的,而它不是ECMAScript标准的一部分。XqRHTML5中文学习网 - HTML5先行者学习网
        这将意味着存在各种浏览器的兼容性问题。for each in,对很多浏览器都不支持的。例如是不支持IE6,IE7,IE8等浏览器的。XqRHTML5中文学习网 - HTML5先行者学习网

区别二:XqRHTML5中文学习网 - HTML5先行者学习网

    例:  var 长方形= {  高:"15",  宽:"25"  };XqRHTML5中文学习网 - HTML5先行者学习网

  for (var i in 长方形){    alert( i + "," + 长方形[i] );  }

    结果依次是:  高,15  ;    宽,25 ;XqRHTML5中文学习网 - HTML5先行者学习网

  for each (var i in 长方形){    alert( i + "," + 长方形[i] );  }

    结果依次是: 15, undefined ;    25, undefined;XqRHTML5中文学习网 - HTML5先行者学习网

    两种遍历方法的变量i的值是不一样的,for each in无法获得对象的属性名,只能获取到属性值。XqRHTML5中文学习网 - HTML5先行者学习网

    最后总结一下使用建议:XqRHTML5中文学习网 - HTML5先行者学习网

    (1)遍历普通数组,建议使用原生的遍历方法for,不要贪图方便,因为for in 和for each in均存在浏览器的兼容问题,不能保证它们对数组的遍历顺序(如果对顺序的不作要求的话,可以使用for in ,但本人不建议),有兴趣话,可以阅读的下一篇文章《关于js中for in的缺陷浅析》。XqRHTML5中文学习网 - HTML5先行者学习网

    (2)遍历对象,由于for没办法提供理想的遍历,因而只能选择其他方法。这里建议使用for in ,从上面讲解的区别,for in比for each 更具优势,for in能获取索引和属性值,而for each只能获取属性值,而且for each在很多低版本的浏览器是不支持。XqRHTML5中文学习网 - HTML5先行者学习网

以上所述就是本文的全部内容了,希望大家能够喜欢XqRHTML5中文学习网 - HTML5先行者学习网

(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助