for/in复制对象属性的疑问

clipboard.png

var o = {x:1,y:2,z:3};
var a = [],i = 0;
for(a[i++] in o){}
console.log(a)//['x','y','z'];
在看权威教程的时候,看到这个代码,有些疑问,声明的空数组a,在for/in循环中a[i++]应该是undefined啊,为何循环出来的是对象o的属性值所组成的数组。这个过程是怎么发生的??

阅读 2.3k
3 个回答

for(a[i++] in o)每次循环的时候,把对象o的属性赋值给a[i],然后i++
所以
第一次遍历的时候,遍历出o的属性"x",然后把"x"赋值给a[i],此时i等于0,所以是a[0] = "x",然后i++,此时i变成1a变成["x"];
第二次遍历的时候,遍历出o的属性"y",然后把"y"赋值给a[i],此时i等于1,所以是a[1] = "y",然后i++,此时i变成2a变成["x", "y"];
第三次遍历的时候,遍历出o的属性"z",然后把"z"赋值给a[i],此时i等于2,所以是a[2] = "z",然后i++,此时i变成3a变成["x", "y", "z"];
遍历结束,a的值变成['x','y','z']i的值变成3

for(i in o){}这里i 为o的key,也就是x,y,z
相当于 循环时a[0] = i,a[1] = i....
所以a为['x','y','z']

for-in语句遍历 o 属性的时候,每次遍历到1个属性会间接把该属性键名赋值给a[i](随后i++)。所以最后 a 会打印出 o 的所有键名。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题