js中处理树形数据

平时开发中会经常碰到树形数据,而我们存储的数据往往是扁平的数据,需要在前端或者后端对数据进行进一步处理成前端组件需要的树形数据。在操作完树形数据后再转换成扁平数据发给后端。下面JavaScript 中处理树形数据的方法,包括构建树和解析树。

一、构建树

假设我们有一个扁平的数组数据,每个元素包含 idparentIdname 等属性,我们可以将其构建为树形结构。以下是一个实现函数:

javascript 复制代码
function buildTree(arr, parentId = null) {
  let tree = [];
  arr.forEach(item => {
    if (item.parentId === parentId) {
      let children = buildTree(arr, item.id);
      if (children.length > 0) {
        item.children = children;
      }
      tree.push(item);
    }
  });
  return tree;
}

以下是使用示例:

javascript 复制代码
let flatData = [
  { id: 1, parentId: null, name: 'Root' },
  { id: 2, parentId: 1, name: 'Child 1' },
  { id: 3, parentId: 1, name: 'Child 2' },
  { id: 4, parentId: 3, name: 'Grandchild 1' }
];
let treeData = buildTree(flatData);
console.log(treeData);

解释:

  • buildTree 函数接收一个扁平数组 arr 和一个可选的 parentId 作为参数,默认为 null,用于表示根节点。
  • 函数使用 forEach 遍历数组中的每个元素。
  • 如果元素的 parentId 等于传入的 parentId,则递归调用 buildTree 函数查找其子节点,并将结果存储在 children 属性中。
  • 最终将满足条件的元素添加到 tree 数组中。

二、解析树

假设我们有一个树形结构的数据,我们要将其解析为一个扁平的数组。以下是一个实现函数:

javascript 复制代码
function flattenTree(tree, parentId = null) {
  let flatArray = [];
  tree.forEach(item => {
    let newItem = {...item };
    newItem.parentId = parentId;
    flatArray.push(newItem);
    if (item.children) {
      flatArray = flatArray.concat(flattenTree(item.children, item.id));
    }
  });
  return flatArray;
}

以下是使用示例:

javascript 复制代码
let treeData = [
  {
    id: 1,
    name: 'Root',
    children: [
      { id: 2, name: 'Child 1' },
      {
        id: 3,
        name: 'Child 2',
        children: [
          { id: 4, name: 'Grandchild 1' }
        ]
      }
    ]
  }
];
let flatData = flattenTree(treeData);
console.log(flatData);

解释:

  • flattenTree 函数接收一个树形结构 tree 和一个可选的 parentId 作为参数,默认为 null
  • 函数使用 forEach 遍历树中的每个元素。
  • 首先将当前元素复制到 newItem 中,并设置 parentId
  • newItem 加入到 flatArray 中。
  • 如果元素有 children,递归调用 flattenTree 函数将子节点添加到 flatArray 中,并将当前元素的 id 作为子节点的 parentId
相关推荐
坚果派·白晓明7 小时前
【鸿蒙PC三方库移植适配框架解读系列】第八篇:扩展lycium框架使其满足rust三方库适配
c语言·开发语言·华为·rust·harmonyos·鸿蒙
花间相见7 小时前
【PaddleOCR教程01】PP-OCRv5 全面指南:从模型架构到实战部署
开发语言·r语言
小短腿的代码世界7 小时前
Qt 股票订单撮合引擎:高频交易系统的核心心脏
开发语言·数据库·qt·系统架构·交互
不会敲代码17 小时前
手写 Zustand:三十分钟带你搞懂状态管理库的核心原理
前端·javascript·源码
神奇的程序员8 小时前
重构了自己5年前写的截图插件
前端·javascript·架构
橙淮8 小时前
从优化到安全再到未来 ——JavaScript 全维度技术指南
javascript
谙弆悕博士9 小时前
快速学C语言——第16章:预处理
c语言·开发语言·chrome·笔记·创业创新·预处理·业界资讯
诚实可靠王大锤9 小时前
React Native 输入框与按钮焦点冲突解决方案(rn版本0.70.3)
前端·javascript·react native·react.js
yuan199979 小时前
基于 C# 实现的 Omron HostLink (FINS) 协议 PLC 通讯
开发语言·c#
qq_4228286210 小时前
android图形学之SurfaceControl和Surface的关系 五
android·开发语言·python