博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
js for in
阅读量:4947 次
发布时间:2019-06-11

本文共 1521 字,大约阅读时间需要 5 分钟。

              Script中for..in循环陷阱

大家都知道在 中提供了两种方式迭代对象:
 
  (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
 
一切又完好如初,哎,不知道,同志们看完有什么感受,是不是有种“拨开云雾见晴天”的感觉啊,呵呵

转载于:https://www.cnblogs.com/yelongsan/p/6509126.html

你可能感兴趣的文章
Delphi 接口机制真相
查看>>
linux下的zookeeper启动
查看>>
重定向和servlet生命周期
查看>>
待看:《未来简史》樊登读书会
查看>>
二代测序技术总结
查看>>
Wpf-Treeview
查看>>
Mac下安装redis
查看>>
浅谈使用 PHP 进行手机 APP 开发(API 接口开发)(转)
查看>>
如何创建新控件? “复合控件”“定制控件”
查看>>
配置C8051F020模板工程
查看>>
秒杀——接口优化
查看>>
Memcached部署(下)
查看>>
箭头函数语法学习()
查看>>
Ext JS学习第十三天 Ext基础之 Ext.Element
查看>>
python--迭代器与生成器
查看>>
SQL之case when then用法详解
查看>>
STL 排序函数
查看>>
Microsoft Dynamics CRM 2011 面向Internet部署 (IFD) ADFS虚拟机环境搭建的步骤(CRM与ADFS装在同一台服务器上) 摘自网络...
查看>>
Setting up a Passive FTP Server in Windows Azure VM(ReplyCode: 227, Entering Passive Mode )
查看>>
PHP链接mongodb数据库并进行增删查改的例子
查看>>