随笔 - 77  文章 - 0  评论 - 9  阅读 - 21万

JS——如果数组中的信息存在多个相同的属性,那么则将这些相同的信息放到同一个children中。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
var arr = [
                   {name: '张三', age: 10, sex: '男'},
                   {name: '李四', age: 10, sex: '男'},
                   {name: '钱五', age: 11, sex: '女'},
                   {name: '赵六', age: 12, sex: '女'},
                   {name: '王七', age: 10, sex: '男'},
               ]
               // // 针对arr,根据相同的age 得出如下结果:
               // result = [
               //     {name: '混合装大保健', age: '******', sex: '你猜', children: [
               //        {name: '张三', age: 10, sex: '男'},
               //        {name: '李四', age: 10, sex: '男'},
               //        {name: '王七', age: 10, sex: '男'},
               //     ]},
               //     {name: '钱五', age: 11, sex: '女'},
               //     {name: '赵六', age: 12, sex: '女'},
               // ]
 
               // Ⅰ:解(8号技师为你服务):
               let obj = {};
               for( let item of arr){
                   if( !obj[`${ item.age }`]){
                       obj[`${ item.age }`] = {
                           name: item.name,
                           age: item.age,
                           sex: item.sex,
                           children: [ item],
                       }
                   }else {
                       obj[`${ item.age }`]['children'].push( item);
                   }
               }
               let _newArr = Object.values( obj);  // 通过Object.values() 得出以属性值为基准的集合。例如:var obj = { 0: 'a', 1: 'b', 2: 'c' }; console.log(Object.values(obj)); // 得出 ['a', 'b', 'c']
               // console.log('~~ 看看:', _newArr);
               // 得出如下结果:
               // [
               //     {
               //         "name": "张三","age": 10,"sex": "男","children": [
               //             {"name": "张三","age": 10,"sex": "男"},
               //             {"name": "李四","age": 10,"sex": "男"},
               //             {"name": "王七","age": 10,"sex": "男"}
               //         ]
               //     },
               //     {"name": "钱五","age": 11,"sex": "女","children": [
               //             {"name": "钱五","age": 11,"sex": "女"}
               //         ]
               //     },
               //     {"name": "赵六","age": 12,"sex": "女","children": [
               //             {"name": "赵六", "age": 12,"sex": "女"}
               //         ]
               //     }
               // ]
                
               // ...Ⅱ:进一步处理(贵客请进屋)。如果age只存在一个,那么将该信息中的children删除;并对非一个的信息行做处理。
               _newArr.forEach( item => {
                   if( item.children.length === 1 && item.age === item.children[ 0].age) {
                       delete item.children;
                   }else {
                       item.name = '混合装大保健';
                       item.age = '******';
                       item.sex = '你猜';
                   }
               });
               // console.log('最后看下:', _newArr); // 得出结果即为上述所说。

  

posted on   _xinT  阅读(405)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示