首先,在JavaScript中,通常不建议使用for ... in
来迭代数组。有关详细信息,请参见为什么在数组迭代中使用for...in
是个坏主意?
因此,您可以尝试像这样做:
var groups = {};
for (var i = 0; i < myArray.length; i++) {
var groupName = myArray[i].group;
if (!groups[groupName]) {
groups[groupName] = [];
}
groups[groupName].push(myArray[i].color);
}
myArray = [];
for (var groupName in groups) {
myArray.push({group: groupName, color: groups[groupName]});
}
在这里使用中介对象groups
可以提高速度,因为它允许您避免嵌套循环来搜索数组。另外,由于groups
是一个对象(而不是一个数组),使用for ... in
来迭代它是适当的。
附录
顺便说一下,如果您想在结果数组中避免重复的颜色条目,您可以在groups[groupName].push(myArray[i].color);
这行代码上面添加一个if
语句来防止重复。使用jQuery的话会像这样:
if (!$.inArray(myArray[i].color, groups[groupName])) {
groups[groupName].push(myArray[i].color);
}
如果没有jQuery,您可能需要添加一个函数,执行与jQuery的inArray
相同的操作:
Array.prototype.contains = function(value) {
for (var i = 0; i < this.length; i++) {
if (this[i] === value)
return true;
}
return false;
}
然后像这样使用:
if (!groups[groupName].contains(myArray[i].color)) {
groups[groupName].push(myArray[i].color);
}
请注意,不论哪种情况,由于所有额外的迭代,您都会稍微减慢速度。因此,如果您不需要避免在结果数组中出现重复的颜色条目,我建议避免使用此额外代码。