js对象数组(JSON) 根据某个共同字段 分组
2017-08-29 17:50
323 查看
希望的是将下面的对象数组:
[ {"id":"1001","name":"值1","value":"111"}, {"id":"1001","name":"值1","value":"11111"}, {"id":"1002","name":"值2","value":"25462"}, {"id":"1002","name":"值2","value":"23131"}, {"id":"1002","name":"值2","value":"2315432"}, {"id":"1003","name":"值3","value":"333333"} ]
根据相同id字段分组,转换成下面这种形式:
[ { "id": "1001", "name": "值1", "data": [ {"id": "1001", "name": "值1", "value": "111"}, { "id": "1001", "name": "值1", "value": "11111"} ] }, { "id": "1002", "name": "值2", "data": [ { "id": "1002", "name": "值2", "value": "25462" }, { "id": "1002", "name": "值2", "value": "23131"}, {"id": "1002", "name": "值2","value": "2315432" } ] }, { "id": "1003", "name": "值3", "data": [ {"id": "1003", "name": "值3", "value": "333333" } ] } ]
做法:
var arr = [ {"id":"1001","name":"值1","value":"111"}, {"id":"1001","name":"值1","value":"11111"}, {"id":"1002","name":"值2","value":"25462"}, {"id":"1002","name":"值2","value":"23131"}, {"id":"1002","name":"值2","value":"2315432"}, {"id":"1003","name":"值3","value":"333333"} ]; var map = {}, dest = []; for(var i = 0; i < arr.length; i++){ var ai = arr[i]; if(!map[ai.id]){ dest.push({ id: ai.id, name: ai.name, data: [ai] }); map[ai.id] = ai; }else{ for(var j = 0; j < dest.length; j++){ var dj = dest[j]; if(dj.id == ai.id){ dj.data.push(ai); break; } } } } console.log(dest);
相关文章推荐
- js对象数组(JSON) 根据某个共同字段 分组
- js对象数组(JSON) 根据某个共同字段 分组
- js对象数组(JSON) 根据某个共同字段 分组
- js对象数组(JSON) 根据某个共同字段 分组
- js对象数组 根据某个共同字段 分组
- 基于JavaScript实现Json数据根据某个字段进行排序
- MySql根据条件分组,然后将某些字段进行拼接
- 根据json来生成打印java字段(属性),解析方法,类--1
- 根据某字段分组,获取当前数据成功或失败各自的统计数
- 基于JavaScript实现Json数据根据某个字段(json中的某个属性)进行排序
- 将不确定变为确定~Linq的Group是否可以根据多个字段进行分组
- SQL根据某个字段分组查询:
- 根据实体类字段分组
- mysql group by分组,根据一个字段分组 ,又想得到另一个字段的最大或者最小。如何解决。
- orcale 根据截取字段,分组
- mysql 根据多个字段分组
- 根据json里的某个key对json数据进行分组
- json数组本地获取,以及根据字段排序【部分摘录】
- mysql根据某个字段分组根据更新时间获取最新的记录
- Python cookbook(数据结构与算法)根据字段将记录分组操作示例