首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Vanilla JS中对象数组的多级分组

在Vanilla JS中,对象数组的多级分组是指根据数组中的对象的一个或多个属性对数组进行分组,可以将具有相同属性值的对象归类到同一个分组中。

实现对象数组的多级分组可以通过以下步骤:

  1. 首先,定义一个空的结果对象,用于存储分组后的结果。
  2. 遍历对象数组,对每个对象进行分组操作。
  3. 获取当前对象指定属性的值,作为分组的依据。
  4. 检查结果对象是否已存在该属性值的分组,如果不存在,则创建一个新的分组,并将当前对象添加到该分组中。
  5. 如果已存在该属性值的分组,则直接将当前对象添加到该分组中。
  6. 继续遍历下一个对象,重复步骤3到步骤5,直到遍历完所有对象。
  7. 最后,将结果对象转换为数组形式,并返回结果数组。

下面是一个示例代码,演示了如何在Vanilla JS中实现对象数组的多级分组:

代码语言:txt
复制
function groupBy(arr, ...props) {
  return arr.reduce((result, obj) => {
    let currentGroup = result;
    props.forEach((prop, index) => {
      const value = obj[prop];
      let subGroup = currentGroup.find(group => group.value === value);
      if (!subGroup) {
        subGroup = { value, children: [] };
        currentGroup.push(subGroup);
      }
      currentGroup = subGroup.children;
      if (index === props.length - 1) {
        subGroup.items = subGroup.items || [];
        subGroup.items.push(obj);
      }
    });
    return result;
  }, []);
}

// 示例用法
const data = [
  { id: 1, category: 'A', subcategory: 'X', name: 'Object 1' },
  { id: 2, category: 'A', subcategory: 'X', name: 'Object 2' },
  { id: 3, category: 'A', subcategory: 'Y', name: 'Object 3' },
  { id: 4, category: 'B', subcategory: 'Z', name: 'Object 4' },
  { id: 5, category: 'B', subcategory: 'Z', name: 'Object 5' }
];

const groupedData = groupBy(data, 'category', 'subcategory');

console.log(groupedData);

上述代码中,我们定义了一个名为groupBy的函数,它接受一个对象数组和一个或多个属性作为参数。函数使用reduce方法对数组进行迭代,遍历每个对象并根据指定的属性值进行分组。最终的分组结果存储在一个嵌套的对象结构中,其中每个分组都具有value属性表示属性值,children属性表示子分组,items属性表示属于该分组的对象数组。

对于这个问题,腾讯云没有特定的产品与之对应。Vanilla JS是原生的JavaScript编程语言,不依赖任何特定的云服务供应商。因此,在这种情况下,不需要提及腾讯云的相关产品。

如果您对其他名词或问题有进一步的疑问,欢迎继续提问。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

JS特殊对象-数组

所谓数组,就是将多个元素(通常是同一类型)按一定顺序排列放到一个集合,那么这个集合我们就称之为数组。...特别注意:JS不像PHP,没有关联数组. 1.2 获取数组元素 // 格式:数组名[下标] 下标又称索引 // 下标从0开始 // 功能:获取数组对应下标的那个值,如果下标不存在,则返回undefined..."pink"; 1.5 数组操作案例 案例1:求数组所有数和 //求和 var arr = [10, 20, 30, 40, 50]; //定义变量存储和 var sum = 0; for (var...arr = [10, 20, 30, 40, 50, 60]; //假设这个变量值是最大 var maxNum = arr[0]; //遍历数组 for (var i = 0; i < arr.length...){ console.log(arr[i]); } } 案例4:将数组转为字符串并以 | 分割 //把数组每个名字后面拼接一个|然后以字符串方式输出 var names =

9.1K00
  • jsmap遍历数组对象_js遍历数组

    forEach()和map()都是遍历数组方法,用法类似,但是还是有很大区别: 相同点:       1.都是循环遍历数组每一项;       2.在遍历执行匿名函数都可以接收三个参数,分别为...:遍历过程每一项、遍历序号(索引值)、原数组;       3.执行匿名函数 this都指向window。...不同点:       map():       根据遍历执行匿名函数,对于原数组每个值产生一个对应值,并返回一个新数组,存在一个映射关系,并且不会改变原数组,不会对空数组进行检测。...forEach匿名函数使用,对于空数组则不会调用到匿名函数。...:",sum); }) //执行5次,最终结果 10 ** js map 遍历数组 ** map 方法会迭代数组每一个元素,并根据回调函数来处理每一个元素,最后返回一个新数组

    19.6K30

    前端基础-JS特殊对象(数组)

    第6章 JS特殊对象-数组 之前学习数据类型,只能存储一个值(比如:Number/String)。我们想在一个变量存储多个值,应该如何存储?...[0]);//undefined 数组元素可以是任意类型数据,因此,有时数组某个元素值又是一个数组,而这样数组被称为多维数组,如果数组只有其他类型数据,而没有另外数组值,这样数组被称为一维数组...; 通常,数组被嵌套N层,则称为N维数组,最常见就是二维数组、三维数组、四维数组,超过一维数组都会被泛称为多维数组数组维度值越大,复杂度就越高,开发尽量避免产生高维度值数组; var arr1..."pink"; 6.5 数组操作案例 案例1:求数组所有数和 //求和 var arr = [10, 20, 30, 40, 50]; //定义变量存储和 var sum = 0; for (var...){ console.log(arr[i]); } } 案例4:将数组转为字符串并以 | 分割 //把数组每个名字后面拼接一个|然后以字符串方式输出 var names =

    3.1K20

    JS 函数 arguments 类数组对象

    1. arguments 介绍 2. arguments 转为数组 3. 箭头函数没有 arguments 1. arguments 介绍 众所周知,js 是一门非常灵活语言。...当我们在 js 调用一个函数时,经常会给函数传递一些参数,js 把调用函数时传入全部实参存储到一个叫做 arguments 数组对象里面 arguments 是一个类数组对象,不是一个真正数组...', 'css', 'js']) 通过打印结果可以发现,arguments 原型是 Object,而数组原型是 Array 那么关于 arguments 是什么 ?...这里做下总结 arguments 是类数组对象(伪数组),即不是一个真正数组,而是一个对象。...它有 length 属性,并且可以通过下标获取元素,但是它不能调用数组方法,就是因为它不是真正数组,这一点可以通过查看它原型验证 2. arguments 转为数组 arguments 是类数组对象

    5.4K20

    JS对象数组案例解析

    以一次实际开发实例,将几种对象数组方法都试了一遍: // const errorList = Object.keys(error) // console.log('error...就是将一个类数组对象或者可遍历对象转换成一个真正数组。...所满足数组限制是: object必须有length属性,返回数组长度取决于length长度 .key 值必须是数值 所以这里输出是空数组 2 .Object.values(object...)(ES8):返回键值遍历器 tips:与第一种不同是不需要length属性,返回一个对象所有可枚举属性值 3.Object.keys(object):返回键名遍历器 tips:返回一个对象自身可枚举属性组成数组...,数组属性名排列顺序和使用 for…in 循环遍历该对象时返回顺序一致 4.Object.entries(object)(ES8):返回键值对遍历器 tips:返回一个给定对象自身可枚举属性键值对数组

    2.4K30

    JS 数组对象深拷贝

    博客地址:https://ainyi.com/72 JavaScript 程序,对于简单数字、字符串可以通过 = 赋值拷贝 但是对于数组对象对象数组拷贝,就有浅拷贝和深拷贝之分 浅拷贝就是当改变了拷贝后数据...b.push(4) a // [1, 2, 3] b // [1, 2, 3, 4] slice() 数组方法 slice() 可从已有的数组返回选定元素 那么设置为 0,就是返回整个数组 let...a // { name: 'krry' } b // { name: 'lily' } --- 以上是简单数组对象深拷贝方法,但是对于二维数组对象数组对象里包含对象,以上方法均达不到深拷贝方法...以上只能达到数组对象第一层==深拷贝==,对于里面的数组对象属性则是==浅拷贝==,因为里面的内存地址只是拷贝了一份,但都是指向==同一个地址== 所以当改变数组对象数组元素或对象,原数据依然会改变...、undefined、symbol,则经过 JSON.stringify() 序列化后 JSON 字符串这个键值对会消失 无法拷贝不可枚举属性,无法拷贝对象原型链 拷贝 Date 引用类型会变成字符串

    8.2K30

    js对象

    js对象 在编程语言中,提到对象,一般都含有一个隐藏上下文面向对象编程。 面向对象编程(Object Oriented Programming,缩写为 OOP)是目前主流编程范式。..., cedf:function(){console.info("cdef")}, "arr":[1,2,3], o:{"name":"jake"} } “在js对象是属性无序集合...1.2 集合 集合是说 对象可以有很多个属性。属性之间用逗号分隔。 1.3 无序 属性与属性之间,没有先后顺序之分。 对比一下,数组元素之间有序。...2. js对象分类 众观整个js对象,可以分成三类: 内置对象 宿主对象 自定义对象 2.1 内置对象 “由ECMA实现、不依赖于宿主环境对象,这些对象js程序执行之前就已经存在了”。...js有两个运行环境: (1) 浏览器。我们在.html文件中加入js代码,再通过浏览器来打开,这里浏览器就是javascript运行环境。 在浏览器端js而言,宿主对象就是浏览器对象

    6.9K50

    js数组、json、js对象区别与联系

    最近在敲代码时,遇上了一个关于JS数组问题,由此引发了关于对象和json联想,曾经觉得很畅顺知识点突然模糊了。于是,为了理清这些东西,有了如下这篇文章。...理清这些问题,第一步当然是找到他们概念:js所有事物都是对象:字符串、数值、数组、函数…此外,JavaScript允许自定义对象 (1)JS数组,常态为var a = [1,2,3]格式,用文字来形容就是一个有序数列...记得上面概念里,js所有事物都是对象,那么我们完全可以把json对象当做js对象子集,string只是js对象key数据类型一个选项 额外说一点,js里面是没有键值对数组这一说,现有的这种键值对数组...(也即是关联数组)其实就是js对象,需要要自己去构造,如: var a = []; a.push({ value:value }); 当然,现在ES6已经有了专门表示键值对数组结构...a[1].name 都是可以使用类似于数组索引,但它实质是js对象object

    9.4K40
    领券