javascript代码实例教程-JavaScript中for..in循环的陷阱

发布时间:2019-02-20 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了javascript代码实例教程-JavaScript中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

 

一切又完好如初,哎,不知道,同志们看完有什么感受,是不是有种“拨开雾见晴天”的感觉啊,呵呵

觉得可用,就经常来吧! 脚本宝典 欢迎评论哦! js脚本,巧夺天工,精雕玉琢。小宝典献丑了!

脚本宝典总结

以上是脚本宝典为你收集整理的javascript代码实例教程-JavaScript中for..in循环的陷阱全部内容,希望文章能够帮你解决javascript代码实例教程-JavaScript中for..in循环的陷阱所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。