js 如何将线性数据转化为树状数据

简介: js 如何将线性数据转化为树状数据

目录


完整代码和结果


  const arr = [
    { name: '内容1', fid: 0, id: 0, },
    { name: '内容2', fid: 0, id: 1, },
    { name: '内容3', fid: 0, id: 2, },
    { name: '内容4', fid: 1, id: 3, },
    { name: '内容5', fid: 1, id: 4, },
    { name: '内容6', fid: 2, id: 5, },
  ]
  const res = []
  // 两个入参 一个是线性对象数组,一个是目标对象
  const addChild = (arr, obj) => {
    // 目标对象的fid
    const { fid } = obj
    // 遍历线性对象数组
    arr.forEach(cur => {
      // 取出遍历的对象的id
      const { id } = cur
      // 判断是否是目标对象的fid
      if (fid === id) {
        // 如果是,先判断加上child指针
        cur.child ? null : cur.child = []
        // 如果加过了,直接加进子级数组
        cur.child.push(obj)
      } else if (cur.child) {
        // 存在子级对象数组,就得判断子级有没有
        addChild(cur.child, obj)
      }
    });
  }
  arr.map(cur => {
    const { id, fid } = cur
    if (id === fid) {
      res.push(cur)
    } else {
      addChild(res, cur)
    }
  })
  console.log(res)

image.png

思想理解


创建线性数据

在创建线性数据时我们就应该为树状数据的转化做准备,什么准备呢?

  const arr = [
    { name: '内容1', fid: 0, id: 0, },
    { name: '内容2', fid: 0, id: 1, },
    { name: '内容3', fid: 0, id: 2, },
    { name: '内容4', fid: 1, id: 3, },
    { name: '内容5', fid: 1, id: 4, },
    { name: '内容6', fid: 2, id: 5, },
  ]

比如我创造一个这样的数据,fid表示它父级节点的id。

特点就是id按顺序排列,且父节点的id会小于子节点的id。

这样我们就可以很容易的生成树状结构,不必担心自己的父级节点比自己晚遍历到,不会造成找不到父级节点的情况。

创建一个结果数组


  const res = []

找到根节点


我们创建了结果数组,树也许不好整,但是把根种下去还是容易吧。

比如你可以提前标好type,我这里是定义自己id与fid相等的为根节点。

我们遍历数据,把定义好的根加入

  arr.map(cur => {
    const { id, fid } = cur
    if (id === fid) {
      res.push(cur)
    } else {
      ...
    }
  })

接下来就是考虑…到底是什么呢,如果不是根,那这个目标对象就是有父节点的了。


既然有父节点,我们就把结果数组遍历一遍找找有没有对应的目标对象的父节点。


我们就需要创建一个找父级的方法。


可能需要两个入参,一个结果数组也就是一个对象数组,和一个正在找父级的目标对象

  addChild(arr,obj)

创建递归方法


我们希望在一个线性的对象数组里找到其中的一个对象,是我们某个目标对象的父级节点。

如果是找到了,就给父级节点加入子级指针指向目标对象。

  // 两个入参 一个是线性对象数组,一个是目标对象
  const addChild = (arr, obj) => {
    // 目标对象的fid
    const { fid } = obj
    // 遍历线性对象数组
    arr.forEach(cur => {
      // 取出遍历的对象的id
      const { id } = cur
      // 判断是否是目标对象的fid
      if (fid === id) {
        // 如果是,先判断加上child指针
        cur.child ? null : cur.child = []
        // 如果加过了,把目标对象直接加进遍历对象的子级数组
        cur.child.push(obj)
      } 
    });
  }

如果不是呢?不是的话就不加了吗,肯定不行。

因为即便当前的遍历对象不是目标对象的父级节点,我们不能保证遍历对象的子级对象数组中没有目标对象的节点。

那么怎么判断子级对象数组有没有呢?

我们发现又是在一个对象数组里面找,所以我们还是调用同样的方法,这就是递归了。

  // 两个入参 一个是线性对象数组,一个是目标对象
  const addChild = (arr, obj) => {
    // 目标对象的fid
    const { fid } = obj
    // 遍历线性对象数组
    arr.forEach(cur => {
      // 取出遍历的对象的id
      const { id } = cur
      // 判断是否是目标对象的fid
      if (fid === id) {
        // 如果是,先判断加上child指针
        cur.child ? null : cur.child = []
        // 如果加过了,直接加进子级数组
        cur.child.push(obj)
      } else if (cur.child) {
        // 存在子级对象数组,就得判断子级有没有
        addChild(cur.child, obj)
      }
    });
  }


相关文章
|
3月前
|
监控 JavaScript 算法
深度剖析 Vue.js 响应式原理:从数据劫持到视图更新的全流程详解
本文深入解析Vue.js的响应式机制,从数据劫持到视图更新的全过程,详细讲解了其实现原理和运作流程。
|
3月前
|
数据采集 存储 JavaScript
如何使用Puppeteer和Node.js爬取大学招生数据:入门指南
本文介绍了如何使用Puppeteer和Node.js爬取大学招生数据,并通过代理IP提升爬取的稳定性和效率。Puppeteer作为一个强大的Node.js库,能够模拟真实浏览器访问,支持JavaScript渲染,适合复杂的爬取任务。文章详细讲解了安装Puppeteer、配置代理IP、实现爬虫代码的步骤,并提供了代码示例。此外,还给出了注意事项和优化建议,帮助读者高效地抓取和分析招生数据。
153 0
如何使用Puppeteer和Node.js爬取大学招生数据:入门指南
|
4月前
|
前端开发 JavaScript
JS-数据筛选
JS-数据筛选
53 7
|
4月前
|
JavaScript 数据安全/隐私保护
2024了,你会使用原生js批量获取表单数据吗
2024了,你会使用原生js批量获取表单数据吗
76 4
|
5月前
|
JavaScript 前端开发 安全
js逆向实战之烯牛数据请求参数加密和返回数据解密
【9月更文挑战第20天】在JavaScript逆向工程中,处理烯牛数据的请求参数加密和返回数据解密颇具挑战。本文详细分析了这一过程,包括网络请求监测、代码分析、加密算法推测及解密逻辑研究,并提供了实战步骤,如确定加密入口点、逆向分析算法及模拟加密解密过程。此外,还强调了法律合规性和安全性的重要性,帮助读者合法且安全地进行逆向工程。
138 11
|
4月前
|
机器学习/深度学习 JSON JavaScript
LangChain-21 Text Splitters 内容切分器 支持多种格式 HTML JSON md Code(JS/Py/TS/etc) 进行切分并输出 方便将数据进行结构化后检索
LangChain-21 Text Splitters 内容切分器 支持多种格式 HTML JSON md Code(JS/Py/TS/etc) 进行切分并输出 方便将数据进行结构化后检索
82 0
|
4月前
|
数据采集 JavaScript 前端开发
JavaScript中通过array.filter()实现数组的数据筛选、数据清洗和链式调用,JS中数组过滤器的使用详解(附实际应用代码)
JavaScript中通过array.filter()实现数组的数据筛选、数据清洗和链式调用,JS中数组过滤器的使用详解(附实际应用代码)
|
5月前
|
JSON JavaScript 前端开发
6-19|Python数据传到JS的方法
6-19|Python数据传到JS的方法
|
6月前
|
Java 开发者 关系型数据库
JSF与AWS的神秘之旅:如何在云端部署JSF应用,让你的Web应用如虎添翼?
【8月更文挑战第31天】在云计算蓬勃发展的今天,AWS已成为企业级应用的首选平台。本文探讨了在AWS上部署JSF(JavaServer Faces)应用的方法,这是一种广泛使用的Java Web框架。通过了解并利用AWS的基础设施与服务,如EC2、RDS 和 S3,开发者能够高效地部署和管理JSF应用。文章还提供了具体的部署步骤示例,并讨论了使用AWS可能遇到的挑战及应对策略,帮助开发者更好地利用AWS的强大功能,提升Web应用开发效率。
85 0
|
6月前
|
移动开发 前端开发 JavaScript
前端表单验证的完美攻略:HTML5属性与JavaScript方法的无缝对接,让你的Web应用数据输入既安全又优雅
【8月更文挑战第31天】本文介绍前端表单验证的重要性及其实现方法,利用HTML5的内置属性如`required`、`pattern`和`minlength`进行基本验证,并借助JavaScript处理复杂逻辑,如密码确认。通过示例代码详细展示了如何结合两者实现高效且友好的表单验证,同时使用CSS增强用户体验。此方法简化开发流程并提升验证效果。
155 0

热门文章

最新文章