js 实现 多层级对象合并

首先

需求是使用js对数据的格式进行转换 把一个二维数组(包含层级信息,层级数是不固定的)list 转换为多层级的对象

我的思路就是 循环先把list里单条信息转换为 多层级对象 然后和上一条 进行合并

原数据类型:

 [{     id:a_a1_a2,     value:1 },{     id:a_a2_a2,     value:2 },{     id:b_b1,     value:3 }]

分别转换为:

 [a{     a1{         a2:1     } }] [a{     a2{         a2:2     } }] [b{     b1:3  }]

最终合并效果:

 {a{     a1{         a2:1     },     a2{         a2:2     }  },  b{     b1:3  }  }
    onSubmit(): void { ​     // 整理 item 数据 ​     let itemsListInfo = {}; ​     //this.addItemListData 存放的原始数据     for (let i = 0; i < this.addItemListData.length; i++) { ​       const itemTree = this.addItemListData[i].id.split('_'); ​       // 按照格式整理 当前item       let thisItemInfo = {}; ​       for (let y = itemTree.length - 1; y >= 0; y--) { ​         if (y === itemTree.length - 1) { ​           thisItemInfo[itemTree[y]] = this.addItemListData[i].value; ​         } else { ​           // 如果直接赋值 会出现问题 需要使用另一个变量暂存           const data = thisItemInfo;           thisItemInfo = {};           thisItemInfo[itemTree[y]] = data; ​         } ​       } ​       console.log(thisItemInfo);       // 合并当前item 到itemListInfo ​       const itemTreeIndex = 0; ​       itemsListInfo = this.margeItem(itemsListInfo, thisItemInfo, itemTree, itemTreeIndex, this.addItemListData[i]); ​     } ​   } ​   margeItem(itemsListInfo: any, thisItemInfo: any, itemTree: any, itemTreeIndex: number, addItemListData: any): any { ​     // 递归 判断是否存在相同层级     // 直到 没有相同层级后 合并对象到上一级     // 注意 如果是初次进入(没有上一级) 就直接赋值 ​     if (itemsListInfo.hasOwnProperty(itemTree[itemTreeIndex])) { ​       itemsListInfo[itemTree[itemTreeIndex]]         = this.margeItem(           itemsListInfo[itemTree[itemTreeIndex]],           thisItemInfo[itemTree[itemTreeIndex]],           itemTree,           itemTreeIndex + 1,           addItemListData         ); ​       return itemsListInfo;     } else { ​       let lastData = {}; ​       if (itemsListInfo.hasOwnProperty(itemTree[itemTreeIndex - 1])) { ​         lastData = itemsListInfo[itemTree[itemTreeIndex - 1]];         lastData[itemTree[itemTreeIndex]] = thisItemInfo[itemTree[itemTreeIndex]]; ​       } else { ​         lastData = thisItemInfo[itemTree[itemTreeIndex]];       } ​       itemsListInfo[itemTree[itemTreeIndex]] = lastData;       return itemsListInfo; ​     } ​   }

最后itemsListInfo就是我需要的最终格式

js 实现 多层级对象合并的更多相关文章

  1. js把两个对象合并成一个对象

    Object.assign() 方法用于将所有可枚举属性的值从一个或多个源对象复制到目标对象.它将返回目标对象 语法: Object.assign(target, ...sources)参数 targ ...

  2. js中数组和对象的合并

    1 数组合并 1.1 concat 方法 1 2 3 4 var a=[1,2,3],b=[4,5,6]; var c=a.concat(b); console.log(c);// 1,2,3,4,5 ...

  3. jQuery对象合并、jQuery添加静态方法、jQuery添加DOM实例方法

    实例效果: 代码演示: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http:/ ...

  4. js之数据类型(对象类型——构造器对象——数组2)

    一.数组空位与undefined 数组空位:数组的某一个位置没有任何值 产生空位的原因:数组中两个逗号之间不放任何值:用new Array()的方法,参数里是个数字:通过一个不存在的下标去增加数组:增 ...

  5. js中对Object对象的一些常用操作总结

    前言我前面的文章,写过js中“类”与继承的一些文章.ES5我们可以通过 构造函数 或者 Object.create()等方式来模拟出js中的“类”,当然,对象呢是类的实例化,我们可以通过如下方式创建对 ...

  6. JS入门之ActiveXObject对象(转载)

    JS入门之ActiveXObject对象   此对象提供自动化对象的接口.   function ActiveXObject(ProgID : String [, location : String] ...

  7. JS中的event 对象详解

    JS中的event 对象详解   JS的event对象 Event属性和方法:1. type:事件的类型,如onlick中的click:2. srcElement/target:事件源,就是发生事件的 ...

  8. js中两个对象的比较

    代码取自于underscore.js 1.8.3的isEqual函数. 做了一些小小的修改,主要是Function的比较修改. 自己也加了一些代码解读. <!DOCTYPE html> & ...

  9. MVC中处理Json和JS中处理Json对象

    MVC中处理Json和JS中处理Json对象 ASP.NET MVC 很好的封装了Json,本文介绍MVC中处理Json和JS中处理Json对象,并提供详细的示例代码供参考. MVC中已经很好的封装了 ...

随机推荐

  1. 字符串(str)

    把字符连成串串. 在python中⽤用', ", ''', """引起来的内容被称为字符串串. 字符串是不可变的对象,所以任何操作对原字符串是不会有任何影响的 ...

  2. Ansible之系列命令详解

    ansible系列命令有:ansible.ansible-doc.ansible-playbook.ansible-vault.ansible-console.ansible-galaxy.ansib ...

  3. 【python测试开发栈】python基础语法大盘点

    周边很多同学在用python,但是偶尔会发现有人对python的基础语法还不是特别了解,所以帮大家梳理了python的基础语法(文中的介绍以python3为例).如果你已然是python大牛,可以跳过 ...

  4. iOS界面流畅技巧之微博 Demo 性能优化技巧

    微博 Demo 性能优化技巧 我为了演示 YYKit 的功能,实现了微博和 Twitter 的 Demo,并为它们做了不少性能优化,下面就是优化时用到的一些技巧. 预排版 当获取到 API JSON ...

  5. oracle实现"limit"功能

    转载于http://blog.sina.com.cn/s/blog_67e2758d0100s3oc.html oracle数据库不支持mysql中limit功能,但可以通过rownum来限制返回的结 ...

  6. ubuntu触摸板双指滑动,页面滚动方向

    setting——mouse & Touchpad——Natural scrolling 跟我的另一台本子一样了-

  7. win10添加启动项目

    Win10启动文件夹一般位于C:\ProgramData\Microsoft\Windows\Start Menu(开始菜单)\Programs(程序)\StartUp(启动)目录,我们主要讲希望添加 ...

  8. opencv 6 图像轮廓与图像分割修复 3 图像的矩,分水岭,图像修补

    图像的矩 矩的计算:moments()函数 计算轮廓面积:contourArea()函数 #include "opencv2/highgui/highgui.hpp" #inclu ...

  9. salesforce lightning零基础学习(十五) 公用组件之 获取表字段的Picklist(多语言)

    此篇参考:salesforce 零基础学习(六十二)获取sObject中类型为Picklist的field values(含record type) 我们在lightning中在前台会经常碰到获取pi ...

  10. 2019-10-10:渗透测试,基础学习,mysql语法基础,笔记

    mysql常用命令mysql -u用户名 -p,登录方式也称为,二进制方式exit 退出mysql 查看mysql版本select version(); 查看mysql所有数据库show dateba ...