FED

©FrontEndDev.org
2015 - 2024
web@2.23.0 api@2.21.1

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

区别一:

  • for in是javascript 1.0 中发布的。
  • for each in是作为E4X标准的一部分在javascript 1.6中发布的,而它不是ECMAScript标准的一部分。

这将意味着存在各种浏览器的兼容性问题。for each in,对很多浏览器都不支持的。例如是不支持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 each in无法获得对象的属性名,只能获取到属性值。

最后总结一下使用建议:

  • (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在很多低版本的浏览器是不支持。
所有评论
这里空空如也
  • /0

Markdown 语法

  • 一级标题
    # 标题
  • 二级标题
    ## 标题
  • 三级标题
    ### 标题
  • 粗体
    **粗体文本**
  • 斜体
    *斜体文本*
  • 引用
    > 引用文本
  • 链接
    [链接描述](url)
  • 图片
    ![alt](url "图片描述")
  • 代码
    `代码`
  • 代码块
    ```编程语言↵
  • 无序列表
    - 项目
  • 有序列表
    1. 项目
  • 分割线
    ---
  • Strikethrough
    ~~text~~
  • Task list
    - [ ] todo

快捷键

  • 粗体
    Ctrl-B
  • 斜体
    Ctrl-I
  • 链接
    Ctrl-K
  • 图片
    Shift-Ctrl-I
  • 代码
    Shift-Ctrl-K
  • 代码块
    Shift-Ctrl-C
  • 无序列表
    Shift-Ctrl-U
  • 有序列表
    Shift-Ctrl-O

目录

    字数: 0行数: 1
    回到顶部
    404