一维数组结构数据转换树形结构数据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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
ZEROZERO
上一篇 2022年11月9日
下一篇 2022年11月10日

相关推荐

  • Java自学之多线程编程

    多线程编程是Java语言最为重要的特性之一。利用多线程技术可以提升单位时间内的程序处理性能,也是现代程序开发中高并发的主要设计模式。 进程与线程 进程是一个应用程序。线程是一个进程…

    2020年12月16日
    1.5K
  • 如何封装JDBC工具类读取properties配置文件连接数据库

    思路 之前已经写过一片《封装JDBC工具类,连接MySQL数据库》,讲解了如何封装JDBC工具类。但是在实际的应用中往往是把数据库连接的相关信息写在一个配置文件中,让程序自己去读取…

    2022年4月2日
    829
  • JavaScript 的 this 原理

    有时候会使用一种东西,并不代表你了解它。就像你会写JavaScript代码,能看懂JavaScript代码,但不代表你懂它。 学懂 JavaScript 语言,一个标志就是理解下面…

    2019年8月1日
    1.7K
  • Angular4.x ngModel 指令详解

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

    2019年7月3日
    1.9K
  • CSS多列等高布局

    在项目开发中,经常遇到需要多列等高布局的需求。解决这种的需求的方法有很多,各有利弊,现总结如下。 方法一:使用flex布局 优点:实现方便,还可以方便实现各种比例 ; 缺点: IE…

    2019年6月11日
    2.1K
  • Java自学之异常的捕获与处理

    在程序开发中,程序的编译与运行是两个不同的阶段,编译主要针对的是语法检测,而在程序运行时却有可能出现各种各样的错误导致程序中断执行,那么这些错误在Java中统一称为异常。 异常处理…

    2020年12月11日
    1.3K
  • MySQL数据库基础之索引相关知识点整理

    数据库对象索引的出现,除了可以提高数据库管理系统的查找速度,而且还可以保证字段的唯一性,从而实现数据库表的完整性。 MySQL支持6种索引:普通索引、唯一索引、全文索引、单列索引、…

    2020年7月9日
    1.6K
  • MyBatis配置之枚举类型typeHandler讲解(上)

    之前发布了一篇《MyBatis配置之typeHandler类型处理器》的文章,讲解了在使用MyBatis时如何自定义typeHandler。但是在MyBatis中枚举类型的type…

    2022年4月21日
    857
  • css如何利用transparent属性设置透明度?transparent属性绘制各种三角形

    想到用css设置元素透明度,大家的第一反应会是:用Opacity属性来设置透明度,其实在css中还有其他设置透明度的方法。本章给大家介绍用transparent属性设置透明度,以及…

    2021年2月25日
    1.3K
  • Java自学之数组

    在Java中数组是一组相关变量的集合,属于引用数据类型。 定义 数组引用传递分析 数组属于引用数据类型,在数组使用时需要通过关键字new开辟堆内存空间,一块堆内存空间也可以同时被多…

    2020年11月26日
    1.2K