最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

JavaScript中for..in循环的陷阱

来源:动视网 责编:小采 时间:2020-11-27 20:30:36
文档

JavaScript中for..in循环的陷阱

JavaScript中for..in循环的陷阱:JavaScript中for..in循环陷阱大家都知道在JavaScript中提供了两种方式迭代对象: (1)for 循环; (2)for..in循环; 使用for循环进行迭代数组对象,想必大家都已经司空见惯了。但是,使用for.. in循环时,大家可要注意了,为什么这么说呢?大家听我娓娓道来
推荐度:
导读JavaScript中for..in循环的陷阱:JavaScript中for..in循环陷阱大家都知道在JavaScript中提供了两种方式迭代对象: (1)for 循环; (2)for..in循环; 使用for循环进行迭代数组对象,想必大家都已经司空见惯了。但是,使用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

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

文档

JavaScript中for..in循环的陷阱

JavaScript中for..in循环的陷阱:JavaScript中for..in循环陷阱大家都知道在JavaScript中提供了两种方式迭代对象: (1)for 循环; (2)for..in循环; 使用for循环进行迭代数组对象,想必大家都已经司空见惯了。但是,使用for.. in循环时,大家可要注意了,为什么这么说呢?大家听我娓娓道来
推荐度:
标签: in js 循环
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top