尝试合并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,'}]
答案 0 :(得分:2)
创建一个1
,2
等来自a
的临时对象作为键并继续添加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]})
}