zoukankan      html  css  js  c++  java
  • js for in

                  JavaScript中for..in循环陷阱

    大家都知道在JavaScript中提供了两种方式迭代对象:
     
      (1)for 循环;
     
      (2)for..in循环;
     
    使用for循环进行迭代数组对象,想必大家都已经司空见惯了。但是,使用for.. in循环时,大家可要注意了,为什么这么说呢?大家听我娓娓道来....
     
    javascript提供了一种特殊的循环(也就是for .. in循环),用来迭代对象的属性或数组的每个元素,for...in循环中的循环计数器是字符串,而不是数字。它包含当前属性的名称或当前数组元素的索引。
     
    案例一:
     
                   //使用for..in循环遍历对象属性
     
                   varperson={
     
                           name: "Admin",
     
                           age: 21,
     
                           address:"shandong"
     
                   };
     
                  
     
                   for(vari in person){
     
                           console.log(i);
     
                   }
     
     
    执行结果为:
     
    name
     
    age
     
    address
     
    当遍历一个对象的时候,变量 i 也就是循环计数器 为 对象的属性名
     
                   //使用for..in循环遍历数组
     
                   vararray = ["admin","manager","db"]
     
                   for(vari in array){
     
                           console.log(i);
     
                   }
     
     
    执行结果:
     
    0
     
    1
     
    2
     
    当遍历一个数组的时候,变量 i 也就是循环计数器 为 当前数组元素的索引
     
     
     
    案例二:
     
    但是,现在看来for .. in循环还挺好用啊,不过,别高兴太早,看看下面的例子:
     
                     var array =["admin","manager","db"];
     
                     //给Array的原型添加一个name属性
     
                     Array.prototype.name= "zhangsan";
     
                     for(var i in array){
     
                        alert(array[i]);
     
                     }
     
    运行结果:
     
    admin
     
    manager
     
    db
     
    zhangsan
     
    咦,奇观了,怎么平白无故的冒出来一个zhangsan
     
    现在,再看看使用 for循环会怎样?
     
                   vararray = ["admin","manager","db"];
     
                    //给Array的原型添加一个name属性
     
                   Array.prototype.name = "zhangsan";
     
                   for(var i =0 ; i<array.length; i++){
     
                          alert(array[i]);
                   };
     
    运行结果:
     
    admin
     
    manager
     
    db
     
    哦, 现在明白了,for..in循环会把某个类型的原型(prototype)中方法与属性给遍历出来,所以这可能会导致代码中出现意外的错误。为了避免这个问题,我们可以使用对象的hasOwnProperty()方法来避免这个问题,如果对象的属性或方法是非继承的,那么hasOwnProperty() 方法返回true。即这里的检查不涉及从其他对象继承的属性和方法,只会检查在特定对象自身中直接创建的属性。
     
    案例三:
     
                   vararray = ["admin","manager","db"];
     
                   Array.prototype.name= "zhangshan";
     
                   for(vari in array){
     
                          //如果不是该对象自身直接创建的属性(也就是该属//性是原型中的属性),则跳过显示
     
                           if(!array.hasOwnProperty(i)){
     
                                   continue;
     
                            }
     
                            alert(array[i]);
     
                   }
     
     
    运行结果:
     
    admin
     
    manager
     
    db
     
    一切又完好如初,哎,不知道,同志们看完有什么感受,是不是有种“拨开云雾见晴天”的感觉啊,呵呵
  • 相关阅读:
    重装系统后无线网卡问题
    U盘重装系统win7
    移动端高清、多屏适配方案
    javascript闭包
    javascript的this指向
    合作开发,导入MyEclipse项目报错问题
    [LC] 117. Populating Next Right Pointers in Each Node II
    [LC] 443. String Compression
    [LC] 1099. Two Sum Less Than K
    [LC] 149. Max Points on a Line
  • 原文地址:https://www.cnblogs.com/yelongsan/p/6509126.html
Copyright © 2011-2022 走看看