如何在Javascript中迭代数组键?

2022-02-26 00:00:00 arrays key javascript

我有一个用以下代码创建的数组:

var widthRange = new Array();
widthRange[46] = { min:0,  max:52 };
widthRange[66] = { min:52, max:70 };
widthRange[90] = { min:70, max:94 };

我希望在循环中获得每个值46、66、90。我尝试了for (var key in widthRange),但这给了我一大堆额外的属性(我假设它们是对象上的函数)。我无法使用常规for循环,因为值不是连续的。


解决方案

您需要调用hasOwnProperty函数来检查属性是否实际定义在对象本身(相对于其原型),如下所示:

for (var key in widthRange) {
    if (key === 'length' || !widthRange.hasOwnProperty(key)) continue;
    var value = widthRange[key];
}
请注意,您需要单独检查length
但是,您在这里根本不应该使用数组;您应该使用常规对象。所有Javascript对象都充当关联数组。

例如:

var widthRange = { };  //Or new Object()
widthRange[46] = { sel:46, min:0,  max:52 };
widthRange[66] = { sel:66, min:52, max:70 };
widthRange[90] = { sel:90, min:70, max:94 };

相关文章