for in 会遍历自身及其原型链上的所有方法。

有个东西你得知道,叫做hasOwnProperty,它可以将不是自己的变量或函数过滤掉

最后,建议不要使用for in , 第一是效率很低,第二是如果自己不注意,容易遍历出自己想不到的东西。

NEILAO answered 9 years, 4 months ago

1,函数本来就没有forEach这个方法,
Array.prototype.forEach.call(a, function(value, key){console.log(key)});
上面的代码与下面的代码等同:
a.forEach(function(value, key){
console.log(key)
});
写成这样应该理解为什么输出的是undefined了吧

2,for in 是用来遍历对象属性的,也能遍历出数组中的元素.另外一个数组本身也是一个对象,比如说你给a添加一个名为"name"的属性,for in也可以循环出来:
a.name = "Frey";

Yumeko answered 9 years, 4 months ago

forEach = for
for != for in

so
forEach != for in

宮澤有紀寧 answered 9 years, 4 months ago

js没有foreach这个方法,for就带foreach的功能

Himeno酱 answered 9 years, 4 months ago

Array.prototype.forEach 把这句话读(一个单词一个单词的读)10遍你就明白了.

关键字: Array , for , Each .

===========================分隔线=========================
@qianjiahao

请问你的回答中 for in + hasOwnProperty == forEach 这个结论是怎么得出来的??
就拿楼主的代码来说, 请问最后 forEach 的输出结果等于前面的 for in 了吗?
如果你要说他代码里没写 hasOwnProperty 的话,我帮他加上, 代码如下:
请告诉我, 它们哪里相等了???


 function a(){};
a.b = function(){}
for(var key in a){
  if(a.hasOwnProperty(key)){
   console.log(key);
  }
};
Array.prototype.forEach.call(a, function(value, key){console.log(key)});

最后希望你以后在回答问题的时候, 最好能验证一下自己的说法. 否则不正确的回答, 只会让更多人受害.

HJHHJ answered 9 years, 4 months ago

for...in 会遍历对象自身和其原型链上所有可枚举的成员(属性和方法)。

forEach的说明如下:

The forEach() method executes a provided function once per array element.

forEach仅遍历数组元素,即那些可以通过索引访问到的元素。

另外可以通过break来终止for...in,但没有办法终止forEach。


补充下:

要让Array.prototype.forEach在object上调用,需要该对象具有length属性,于是forEach会执行类似的行为:(参考ES5 Spec)


 var i = 0;
while(i++ < length) {
  if(obj.[[hasProperty]](i.toString()))
    callback.call(...)
}

所以Array.prototype.forEach可以应用在Argument对象或者是HTMLCollection对象上.

雅蠛蝶.一库 answered 9 years, 4 months ago

Your Answer