一维数组结构数据转换树形结构数据JS方法

在写小程序项目时,自定义了一个组织机构树形展示组件,后端接口返回的组织机构数据是一维数组。需要在前端转换成树形结构的数据,并且添加一些节点的树形,比如是否为叶子节点,节点是否展开等,在自定义的组件中通过这些属性,做出友好的用户交互效果。

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <script>
      var arr = [
        { id: 0, pid: null, text: "父级" },
        { id: 1, pid: 0, text: "一级1" },
        { id: 2, pid: 0, text: "一级2" },
        { id: 3, pid: 1, text: "二级1-1" },
        { id: 4, pid: 1, text: "二级1-2" },
        { id: 5, pid: 2, text: "二级2-1" },
        { id: 6, pid: 2, text: "二级2-2" },
        { id: 7, pid: 3, text: "三级1-1-1" },
        { id: 8, pid: 7, text: "四级1-1-1-1" },
        { id: 9, pid: 8, text: "五级1-1-1-1-1" },
        { id: 10, pid: 9, text: "六级1-1-1-1-1" },
      ];
      let arrayToTree = function (dataArr, rootId) {
        let arr = JSON.parse(JSON.stringify(dataArr));
        // 获取所有顶级分类,然后组成数组
        let parents = arr.filter((v) => v.pid === rootId);
        // 获取所有非顶级分类,组成数组
        let children = arr.filter((v) => v.pid !== rootId);
        // 定义递归方法, 传入参数,父级数组,和子集数组
        function dataToTree(p, c) {
          // 循环遍历父级数组
          p.forEach((p_v) => {
            // 循环遍历子集数组
            p_v.isOpen = false;
            c.forEach((c_v, c_i) => {
              // 判断当前的子项是否为当前的父项的子元素
              if (c_v.pid === p_v.id) {
                // 如果是那么判断当前,当前父类项是否有children 字段
                if (!p_v.children) {
                  // 如果没有初始化为空数组
                  p_v.children = [];
                  c_v.isLeaf = true;
                }
                // 然后把当前的子类项推到父类的children数组中
                p_v.children.push(c_v);
                // 在执行递归调用当前方法,把当前子类项以数组的形式作为第一个参数传入,然后把所有的子集数组作为第二个参数传入,从新遍历所有子类数组中是否有当前子类的下一级
                // dataToTree([c_v], children);
                p_v.isLeaf = false;
                c_v.isLeaf = true;
                /* 为了减少遍历的次数可以把当前项从子类型中删除 */
                // 然后把所有的子集数组深拷贝一份,因为数组中的项是对象属于引用类型的
                let _c = JSON.parse(JSON.stringify(c));
                //然后把当前子类项从整体的子类数组中剔除
                _c.splice(c_i, 1);
                // 在执行递归调用当前方法,把当前子类项以数组的形式作为第一个参数传入,然后把所有的子集数组作为第二个参数传入,从新遍历所有子类数组中是否有当前子类的下一级
                dataToTree([c_v], _c);
              }
              c_v.isOpen = false;
            });
          });
        }
        dataToTree(parents, children);
        return parents;
      };
      let getTree = arrayToTree(arr, null);
      console.log(getTree);
    </script>
  </head>
  <body></body>
</html>

原创文章,作者:ZERO,如若转载,请注明出处:https://www.edu24.cn/course/array-to-tree-js.html

Like (0)
Donate 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
ZEROZERO
Previous 2022年11月9日
Next 2022年11月10日

相关推荐

  • Java自学之泛型

    在Java语言中,为了方便接收参数类型的统一,提供了核心类Object,利用此类对象可以接收所有类型的数据(包括基本数据类型和引用数据类型)。但是由于其所描述的数据范围过大,所以在…

    2020年12月8日
    1.2K
  • 两栏布局之左侧固定,右侧自适应的实现方法

    实现左侧固定,右侧自适应的两栏布局的方法有很多。其中经常用到的有float方法、BFC方法、CSS3的flex布局及grid布局。并非所有的布局都会在开发中使用,但是其中也会涉及一些知识点。

    2018年10月13日
    2.5K
  • MyBatis配置之properties属性详解

    之前写了一篇《如何搭建MyBatis开发环境》,通过一个简单的实例讲解了关于搭建MyBatis的开发环境,这篇将详细讲解MyBatis的配置。 MyBatis配置文件的层次结构 这…

    2022年4月18日
    690
  • Angular4.x ngModel 指令详解

    用过angular的前端工程师都知道,angular数据是可以双向绑定的。但是它为什么可以使数据双向绑定?原理又是什么?阅读这篇文章,来了解一下吧。

    2019年7月3日
    1.8K
  • Webpack入门,模块打包之CommonJS与ES6 Module的区别

    前面几篇文章分别介绍了CommonJS和ES6 Module两种形式的模块定义,这篇将介绍下两者各自的特性。 动态与静态 CommonJS与ES6 Module最本质的区别在于前者…

    2022年11月12日
    706
  • px、em和rem实战经验

    在自适应布局或者移动端网页开发时,我们经常会用到em和rem两个长度单位。接下来我们讨论一下这两个单位和px之间的区别,以及他们的使用场景等。 px px,像素(计算机屏幕上的一个…

    2018年9月11日
    2.0K
  • css布局基础总结

    前端css布局知识繁杂,实现方式多种多样。想写出高效、合理的布局,必须以深厚的css基础为前提。为了方便记忆和复习,将css布局要点记录如下。内容较多,应用方面说的不太详细,但都是…

    2018年9月13日
    2.2K
  • Java自学之类结构扩展

    面向对象中的核心组成是类与接口,在项目中会利用【包】进行一组相关类的管理,这样适合于程序代码的部分更新,也更加符合面向对象封装性的概念,同时合理地使用封装也可以方便地实现实例化对象…

    2020年12月10日
    1.2K
  • 创建JavaScript对象的六种方式

    第一种:Object 构造函数创建 这行代码创建了 Object 引用类型的一个新实例,然后把实例保存在变量 Person 中。 第二种:使用对象字面量表示法 对象字面量是对象定义…

    2020年6月24日
    1.2K
  • 曾被问及的一些关于VUE的面试题

    由于没有系统的专研过VUE,关于VUE的一些理论知识点,没有去挖心思记忆及理解,只是在实际工作中知道怎么去使用。所以曾在面试的过程中被人嫌弃过,这一直是小编的痛点,/(ㄒoㄒ)/~…

    2022年4月2日
    765