首页 > web前端 > js教程 > 正文

JavaScript中for..in循环的陷阱

高洛峰
发布: 2016-11-28 13:33:39
原创
1509人浏览过

              javascript中for..in循环陷阱

大家都知道在JavaScript中提供了两种方式迭代对象:

 

Check for AI
Check for AI

在论文、电子邮件等中检测AI书写的文本

Check for AI 88
查看详情 Check for AI

立即学习Java免费学习笔记(深入)”;

  (1)for 循环;

 

立即学习Java免费学习笔记(深入)”;

  (2)for..in循环;

 

立即学习Java免费学习笔记(深入)”;

使用for循环进行迭代数组对象,想必大家都已经司空见惯了。但是,使用for.. in循环时,大家可要注意了,为什么这么说呢?大家听我娓娓道来....

 

立即学习Java免费学习笔记(深入)”;

javascript提供了一种特殊的循环(也就是for .. in循环),用来迭代对象的属性或数组的每个元素,for...in循环中的循环计数器是字符串,而不是数字。它包含当前属性的名称或当前数组元素的索引。

 

立即学习Java免费学习笔记(深入)”;

案例一:

               //使用for..in循环遍历对象属性
 
               varperson={
 
                       name: "Admin",
 
                       age: 21,
 
                       address:"shandong"
 
               };
 
              
 
               for(vari in person){
 
                       console.log(i);
 
               }
登录后复制

 

立即学习Java免费学习笔记(深入)”;

执行结果为:

 

立即学习Java免费学习笔记(深入)”;

name

 

立即学习Java免费学习笔记(深入)”;

age

 

立即学习Java免费学习笔记(深入)”;

address

 

立即学习Java免费学习笔记(深入)”;

当遍历一个对象的时候,变量 i 也就是循环计数器 为 对象的属性名

               //使用for..in循环遍历数组
 
               vararray = ["admin","manager","db"]
 
               for(vari in array){
 
                       console.log(i);
 
               }
登录后复制

 

立即学习Java免费学习笔记(深入)”;

 

立即学习Java免费学习笔记(深入)”;

执行结果:

 

立即学习Java免费学习笔记(深入)”;

0

 

立即学习Java免费学习笔记(深入)”;

1

 

立即学习Java免费学习笔记(深入)”;

2

 

立即学习Java免费学习笔记(深入)”;

当遍历一个数组的时候,变量 i 也就是循环计数器 为 当前数组元素的索引

 

立即学习Java免费学习笔记(深入)”;

 

立即学习Java免费学习笔记(深入)”;

 

立即学习Java免费学习笔记(深入)”;

案例二:

 

立即学习Java免费学习笔记(深入)”;

但是,现在看来for .. in循环还挺好用啊,不过,别高兴太早,看看下面的例子:

                 var array =["admin","manager","db"];
 
                 //给Array的原型添加一个name属性
 
                 Array.prototype.name= "zhangsan";
 
                 for(var i in array){
 
                    alert(array[i]);
 
                 }
登录后复制

 

立即学习Java免费学习笔记(深入)”;

运行结果:

 

立即学习Java免费学习笔记(深入)”;

admin

 

立即学习Java免费学习笔记(深入)”;

manager

 

立即学习Java免费学习笔记(深入)”;

db

 

立即学习Java免费学习笔记(深入)”;

zhangsan

 

立即学习Java免费学习笔记(深入)”;

咦,奇观了,怎么平白无故的冒出来一个zhangsan

 

立即学习Java免费学习笔记(深入)”;

现在,再看看使用 for循环会怎样?

               vararray = ["admin","manager","db"];
 
                //给Array的原型添加一个name属性
 
               Array.prototype.name = "zhangsan";
 
               for(var i =0 ; i<array.length; i++){
 
                      alert(array[i]);
               };
登录后复制

 

立即学习Java免费学习笔记(深入)”;

运行结果:

 

立即学习Java免费学习笔记(深入)”;

admin

 

立即学习Java免费学习笔记(深入)”;

manager

 

立即学习Java免费学习笔记(深入)”;

db

 

立即学习Java免费学习笔记(深入)”;

哦, 现在明白了,for..in循环会把某个类型的原型(prototype)中方法与属性给遍历出来,所以这可能会导致代码中出现意外的错误。为了避免这个问题,我们可以使用对象的hasOwnProperty()方法来避免这个问题,如果对象的属性或方法是非继承的,那么hasOwnProperty() 方法返回true。即这里的检查不涉及从其他对象继承的属性和方法,只会检查在特定对象自身中直接创建的属性。

 

立即学习Java免费学习笔记(深入)”;

案例三:

               vararray = ["admin","manager","db"];
 
               Array.prototype.name= "zhangshan";
 
               for(vari in array){
 
                      //如果不是该对象自身直接创建的属性(也就是该属//性是原型中的属性),则跳过显示
 
                       if(!array.hasOwnProperty(i)){
 
                               continue;
 
                        }
 
                        alert(array[i]);
 
               }
登录后复制

 

立即学习Java免费学习笔记(深入)”;

运行结果:

 

立即学习Java免费学习笔记(深入)”;

admin

 

立即学习Java免费学习笔记(深入)”;

manager

 

立即学习Java免费学习笔记(深入)”;

db

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

相关标签:
java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号