首先,在Javascript中,使用遍历数组通常不是一个好主意
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);}请注意,无论哪种情况,由于所有额外的迭代,您都将放慢速度,因此,如果您不需要避免结果数组中出现重复的颜色条目,我建议您避免使用此额外的代码。那里



