js 实现 多层级对象合并
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 实现 多层级对象合并的更多相关文章
- js把两个对象合并成一个对象
Object.assign() 方法用于将所有可枚举属性的值从一个或多个源对象复制到目标对象.它将返回目标对象 语法: Object.assign(target, ...sources)参数 targ ...
- 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 ...
- jQuery对象合并、jQuery添加静态方法、jQuery添加DOM实例方法
实例效果: 代码演示: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http:/ ...
- js之数据类型(对象类型——构造器对象——数组2)
一.数组空位与undefined 数组空位:数组的某一个位置没有任何值 产生空位的原因:数组中两个逗号之间不放任何值:用new Array()的方法,参数里是个数字:通过一个不存在的下标去增加数组:增 ...
- js中对Object对象的一些常用操作总结
前言我前面的文章,写过js中“类”与继承的一些文章.ES5我们可以通过 构造函数 或者 Object.create()等方式来模拟出js中的“类”,当然,对象呢是类的实例化,我们可以通过如下方式创建对 ...
- JS入门之ActiveXObject对象(转载)
JS入门之ActiveXObject对象 此对象提供自动化对象的接口. function ActiveXObject(ProgID : String [, location : String] ...
- JS中的event 对象详解
JS中的event 对象详解 JS的event对象 Event属性和方法:1. type:事件的类型,如onlick中的click:2. srcElement/target:事件源,就是发生事件的 ...
- js中两个对象的比较
代码取自于underscore.js 1.8.3的isEqual函数. 做了一些小小的修改,主要是Function的比较修改. 自己也加了一些代码解读. <!DOCTYPE html> & ...
- MVC中处理Json和JS中处理Json对象
MVC中处理Json和JS中处理Json对象 ASP.NET MVC 很好的封装了Json,本文介绍MVC中处理Json和JS中处理Json对象,并提供详细的示例代码供参考. MVC中已经很好的封装了 ...
随机推荐
- SSM整合相关试题
1.下列关于Spring自动装配的说法中,错误的是() A 在Spring配置文件中,可以通过<bean>元素的autowire属性指定自动装配方式 B autowire属性值可以设置为n ...
- C语言I博客作业08
这个作业属于那个课程 C语言程序设计II 这个作业要求在哪里 作业 我在这个课程的目标是 熟悉使用while和do-while结构解决问题 这个作业在那个具体方面帮助我实现目标 pta题目及查找的资料 ...
- .NET Core前后端分离快速开发框架(Core.3.0+AntdVue)
.NET Core前后端分离快速开发框架(Core.3.0+AntdVue) 目录 引言 简介 环境搭建 开发环境要求 基础数据库构建 数据库设计规范 运行 使用教程 全局配置 快速开发 管理员登录 ...
- nyoj 242-计算球体积 (pi*r*r*r*4/3)
242-计算球体积 内存限制:64MB 时间限制:3000ms 特判: No 通过数:21 提交数:74 难度:1 题目描述: 根据输入的半径值,计算球的体积. 输入描述: 输入数据有多组,每组占一行 ...
- Python第五天 列表练习 元组类型 字典类型 小购物车练习
# 反转 reverse# l=['lili','asdf','qwer','80000']# l.reverse()# print(l) # ['80000', 'qwer', 'asdf', 'l ...
- 小白学 Python 爬虫(3):前置准备(二)Linux基础入门
人生苦短,我用 Python 前文传送门: 小白学 Python 爬虫(1):开篇 小白学 Python 爬虫(2):前置准备(一)基本类库的安装 Linux 基础 CentOS 官网: https: ...
- Handler+Looper+MessageQueue深入详解
概述:Android中的异步处理机制由四部分组成:Handler+Looper+MessageQueue+message,用于实现线程间的通信. 用到的概念: Handler: 主要作用是发送消息和处 ...
- Linux root设置初始值的方法
Linux root设置初始值的方法 ubuntu默认不允许使用root登录,因此初始root账户是不能使用的,需要在普通账户下利用sudo权限修改root密码. 在终端输入sudo passwd r ...
- CSS中选择器优先级与!important权重使用
CSS中的选择器优先级与!important权重使用 .class选择器要高于标签选择器. #id选择器要高于.class选择器. 标签选择器是优先级最低的选择器. !important的属性它的权重 ...
- linux shell编程之变量和bash配置文件(第一篇)
编程语言有两类 强类型:如C语言.数据具有其特定的类型,先声明定义后才能使用.数据运算时必须符合类型要求(如不能把字符串类型数据直接与整型数据做算数运算) 弱类型:如shell.数据默认为字符型,不用 ...