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. 「动态规划」-数位dp专题

    数位dp,今天学长讲的稍玄学,课下花了一会时间仔细看了一下,发现板子是挺好理解的,就在这里写一些: 数位dp主要就是搞一些在区间中,区间内的数满足题目中的条件的数的个数的一类题,题目一般都好理解,这时 ...

  2. 构建大型 Vue.js 项目的10条建议

    下面是我在开发大型 Vue 项目时的最佳实践.这些技巧将帮助你开发更高效.更易于维护和共享的代码. 今年做自由职业的时候,我有机会开发了一些大型 Vue 应用程序.我所说的这些项目,Vuex stor ...

  3. Spring-boot构建多模块依赖工程时,maven打包异常:程序包xxx不存在

    在qizhi项目改版的时候, 所有代码都迁移好了, 但是compile的时候报程序包*****不存在, 具体到某一个类就是: 找不到符号. 下面这篇文章是正解 http://hbxflihua.ite ...

  4. VLAN实验(3)

    1.选择2台S3700和5台pc机,并根据实验编址完成此拓扑图. 2.启动设备,检查设备的连通性: 由于现在我们还没有划分VLAN,这5台PC,还在同一个VLAN中,现在我们启动所有的设备,这是所有的 ...

  5. Centos上通过shell脚本备份数据库

    #!/bin/bash ds=`` list=`date +%Y`/`date +%m` dname="callme" eval "mkdir -p $list" ...

  6. Java IO入门

    目录 一. 数据源(流) 二. 数据传输 三. 总结 我们从两个方面来理解Java IO,数据源(流).数据传输,即IO的核心就是对数据源产生的数据进行读写并高效传输的过程. 一. 数据源(流) 数据 ...

  7. elementui 模态框 拖动

    第一步引入import elDragDialog from "@/directive/el-dragDialog";第二步 在export default中声明directives ...

  8. kali下安装mobsf

    1.查看kali版本,安装mobsf对kali版本的要求是大于3.0并且是64位 uname -a 2.安装docker,有选择的地方直接回车就好 apt-get install docker doc ...

  9. (六)OpenStack---M版---双节点搭建---Neutron安装和配置

    ↓↓↓↓↓↓↓↓视频已上线B站↓↓↓↓↓↓↓↓ >>>>>>传送门 1.创建网络服务数据库 2.获得 admin 凭证来获取只有管理员能执行的命令的访问权限 3.创 ...

  10. springboot+logback日志输出企业实践(下)

    目录 1.引言 2. 输出 logback 状态数据 3. logback 异步输出日志 3.1 异步输出配置 3.2 异步输出原理 4. springboot 多环境下 logback 配置 5. ...