尝试合并json数组的重复键并以csv格式构建相应的值.
A=[{a:1,b:2},{a:1,b:1},{a:1,b:6},{a:2,b:5},{a:2,b:3}]
试图转换
A=[{a:'1',b:'2,1,6'},{a:2,b:'5,3'}]
我试过的代码
var existingIDs = [];
A= $.grep(A, function (v) {
if ($.inArray(v.a, existingIDs) !== -1) {
return v.b+= ',';
}
else {
existingIDs.push(v.a);
return true;
}
});
输出就像返回一样
A=[{a:1,b:2},{a:1,b:'1,'},{a:1,b:'6,'},{a:2,b:5},{a:2,b:'3,'}]
最佳答案 使用as键创建一个带有1,2等的临时对象并继续添加b值,然后迭代该对象创建新数组:
var A = [{a:1,b:2},{a:1,b:1},{a:1,b:6},{a:2,b:5},{a:2,b:3}];
var temp = {};
for (var i=0; i<A.length; i++) {
temp[A[i].a] =
temp[A[i].a] === undefined ?
A[i].b :
temp[A[i].a] + ',' + A[i].b;
}
A = [];
for (var key in temp) {
A.push({a: key, b:temp[key]})
}