大家都知道在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 
一切又完好如初,哎,不知道,同志们看完有什么感受,是不是有种“拨开云雾见晴天”的感觉啊

最新文章

  1. 【原创经验分享】WCF之消息队列
  2. Linux查找命令:grep,awk,sed
  3. vs2010问题:未能安装xxx包
  4. js-JavaScript高级程序设计学习笔记7
  5. SSM的各个配置文件
  6. C# 毕业证书打印《六》
  7. 【读书笔记】iOS-属性列表
  8. Base适配器
  9. python &amp; pandas链接mysql数据库
  10. ssh超时断开的解决方法
  11. 文本替换sed+字段处理cut,join+awk重新编排字段
  12. Windows提供了两种将DLL映像到进程地址空间的方法(隐式和显式)
  13. NPOI导入导出Excel
  14. 【Android 应用开发】Android 图表绘制 achartengine 示例解析
  15. MT【324】增量代换
  16. python 包 笔记
  17. Unity3D编辑器扩展(五)——常用特性(Attribute)以及Selection类
  18. [java]创建一个默认TreeMap() key为什么不能为null
  19. val和var和Java
  20. mysql分页查询优化(索引延迟关联)

热门文章

  1. g++优化开关(暴力必备)
  2. python sorted()的简单使用
  3. ajax 工作原理
  4. 使用sqlyog工具同步两个相同结构的数据库之间的数据
  5. 转: 工作中用的C++库
  6. leetcood学习笔记-168-excel表列名称
  7. bzoj1009题解
  8. NX二次开发-UFUN设置视图边界线显示隐藏UF_DRAW_set_border_display
  9. NX二次开发-删除功能区工具栏UF_UI_remove_ribbon
  10. csp-s模拟测试99