Javascript for()循环变体

时间:2012-11-14 10:52:39

标签: javascript for-loop

我正在使用以下属性创建此元素:

var x = document.createElement('x');
x.setAttribute('ha','1');
x.setAttribute('he','2');
x.setAttribute('hi','3');

然后我使用这两种形式循环它,每次都得到不同的输出:

>>>for(var i in x.attributes) console.log(x.attributes[i]);
ha="1"
he="2"
hi="3"
3
item()
getNamedItem()
setNamedItem()
removeNamedItem()
getNamedItemNS()
setNamedItemNS()
removeNamedItemNS()

另一个:

>>>for(var i=0;i<x.attributes.length;i++) console.log(x.attributes[i]);
ha="1"
he="2"
hi="3"

那么,这不应该给出相同的结果吗?为什么不呢?

2 个答案:

答案 0 :(得分:5)

for...in方法遍历对象的所有属性,包括“本机”属性。要将输出限制为您定义的属性:

for (var i in obj) {
    if (obj.hasOwnProperty(i)) {
        console.log(i);
    }
}

参考文献:

答案 1 :(得分:5)

这是因为你从原型中获得了所有东西。使用hasOwnProperty仅迭代已设置的属性:

for(var i in x.attributes){ 
    if (x.hasOwnProperty(i)) {
        console.log(x.attributes[i]);
    }
}