首先,在 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
是合适的。
附录
FWIW,如果您想避免在结果数组中出现重复的颜色条目,您可以if
在该行上方添加一条语句groups[groupName].push(myArray[i].color);
以防止重复。使用 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);
}
请注意,在任何一种情况下,由于所有额外的迭代,您都会稍微减慢速度,因此如果您不需要避免结果数组中的重复颜色条目,我建议避免使用此额外代码。那里