如何将JavaScript将数组转为树形结构


Posted in Javascript onJune 02, 2021

1.需求

后台给了一个这样的数据让咱前端去转换为树形结构(没有重复数据)。不多说,先来看看给了一个怎样的数组数据,转换为怎样的树形结构。

服务器传过来的数组

const arr = [
      [
        {"deptId":"D019",
        "deptName":"销售部"},
        {"deptId":"D019101",
        "deptName":"华北销售中心"}
      ],[
        {"deptId":"D083",
        "deptName":"音乐事业部"}
      ],[
        {"deptId":"D027",
        "deptName":"杭州研究院"},
        {"deptId":"D027048",
        "deptName":"技术工程事业部"},
        {"deptId":"D027048002",
        "deptName":"项目管理中心"}
      ],[
        {"deptId":"D027",
        "deptName":"杭州研究院"},
        {"deptId":"D027048",
        "deptName":"技术工程事业部"}
      ],[
        {"deptId":"D027",
        "deptName":"杭州研究院"},
        {"deptId":"D027048",
        "deptName":"技术工程事业部"}
      ]
    ]

最终转换为

const arr = [
    {
      deptId: 'D019',
      deptName: '销售部',
      children: [{
        deptId: 'D019101',
        deptName: '华北销售中心',
        children: [],
      }]
    },
    {
      deptId: 'D083',
      deptName: '音乐事业部',
      children: []
    },
    {
      deptId: 'D027',
      deptName: '杭州研究院',
      children: [{
        deptId: 'D027048',
        deptName: '技术工程事业部',
        children: [{
          deptId: 'D027048002',
          deptName: '项目管理中心',
          children: []
        }]
      }]
    },
  ]

2.上代码(在reactHooks中开发)

const [treeData, setTreeData] = useState([]);
  console.log(treeData); //treeData为最终需要的树形结构,(在我本地浏览器打印出来是正确的)
  
  useEffect(() => {
    const str = '[[{"deptId":"D019","deptName":"销售部"},{"deptId":"D019101","deptName":"华北销售中心"}],[{"deptId":"D019","deptName":"销售部"},{"deptId":"D019101","deptName":"华北销售中心"}],[{"deptId":"D083","deptName":"音乐事业部"}],[{"deptId":"D027","deptName":"杭州研究院"},{"deptId":"D027048","deptName":"技术工程事业部"},{"deptId":"D027048002","deptName":"项目管理与效能中心"}],[{"deptId":"D027","deptName":"杭州研究院"},{"deptId":"D027048","deptName":"技术工程事业部"}],[{"deptId":"D027","deptName":"杭州研究院"},{"deptId":"D027048","deptName":"技术工程事业部"}]]';
    const arr = JSON.parse(str).flat(); //扁平化

    let newArr = [];
    noRepeat(arr).length && noRepeat(arr).forEach(it => {
      appendChild(it, newArr);
    });
  }, [])

  const noRepeat = (arr) => { //去重
    let newobj = {}; 
    return arr.reduce((preVal, curVal) => {
    newobj[curVal.deptId] ? '' : newobj[curVal.deptId] = preVal.push(curVal); 
      return preVal 
    }, []);
  }

  const appendChild = (item, newArr) => {
    if(!newArr.find(it => item.deptId.indexOf(it.deptId) > -1)) { //所有一级部门
      newArr.push({
        deptId: item.deptId,
        deptName: item.deptName,
        children: [],
      });
      setTreeData(newArr);
    }else {
      appendOtherChild(item, newArr);
    }
  }

  const appendOtherChild = (item, newArr) => {
    newArr.map(it => {
      if(item.deptId.indexOf(it.deptId) > -1 && item.deptId.length === it.deptId.length+3) {
        it.children.push({
          deptId: item.deptId,
          deptName: item.deptName,
          children: [],
        })
      }else {
        appendOtherChild(item, it.children);
      }
    });
    setTreeData(newArr);
  }

总结

可能这些数据和你的不太一样,但是逻辑可能八九不离十,可以好好看一下这几十行代码

到此这篇关于如何将JavaScript将数组转为树形结构的文章就介绍到这了,更多相关JavaScript数组转为树形结构内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
node.js中的fs.createWriteStream方法使用说明
Dec 17 Javascript
JS获取表格内指定单元格html内容的方法
Mar 31 Javascript
jQuery代码实现表格中点击相应行变色功能
May 09 Javascript
js 上传文件预览的简单实例
Aug 16 Javascript
XMLHttpRequest Level 2 使用指南
Aug 26 Javascript
微信js-sdk界面操作接口用法示例
Oct 12 Javascript
jQuery插件form-validation-engine正则表达式操作示例
Feb 09 Javascript
BootStrap注意事项小结(五)表单
Mar 10 Javascript
详解Vue快速零配置的打包工具——parcel
Jan 16 Javascript
浅谈React之状态(State)
Sep 19 Javascript
vue基于better-scroll实现左右联动滑动页面
Jun 30 Javascript
解决VUE 在IE下出现ReferenceError: Promise未定义的问题
Nov 07 Javascript
关于antd tree 和父子组件之间的传值问题(react 总结)
使用react+redux实现计数器功能及遇到问题
微信小程序基础教程之echart的使用
vue实现水波涟漪效果的点击反馈指令
vue 实现上传组件
May 31 #Vue.js
vue基于Teleport实现Modal组件
Vue+Element UI实现概要小弹窗的全过程
You might like
php 获取完整url地址
2008/12/20 PHP
深入解析phpCB批量转换的代码示例
2013/06/27 PHP
php最简单的删除目录与文件实现方法
2014/11/28 PHP
php中preg_replace正则替换用法分析【一次替换多个值】
2017/01/17 PHP
详谈php ip2long 出现负数的原因及解决方法
2017/04/05 PHP
Laravel框架处理用户的请求操作详解
2019/12/20 PHP
Thinkphp 框架基础之入口文件功能、定义与用法分析
2020/04/27 PHP
IE与firefox之jquery用法区别
2008/10/03 Javascript
js 事件截取enter按键页面提交事件示例代码
2014/03/04 Javascript
js读取json的两种常用方法示例介绍
2014/10/19 Javascript
使用Browserify配合jQuery进行编程的超级指南
2015/07/28 Javascript
jquery实现清新实用的网页菜单效果
2015/08/28 Javascript
js确认框confirm()用法实例详解
2016/01/07 Javascript
webpack本地开发环境无法用IP访问的解决方法
2018/03/20 Javascript
js限制输入框只能输入数字(onkeyup触发)
2018/09/28 Javascript
vue中v-for循环给标签属性赋值的方法
2018/10/18 Javascript
小程序日历控件使用方法详解
2018/12/29 Javascript
详解用async/await来处理异步
2019/08/28 Javascript
Python线性方程组求解运算示例
2018/01/17 Python
Python使用pymysql从MySQL数据库中读出数据的方法
2018/07/25 Python
基于python历史天气采集的分析
2019/02/14 Python
python flask 如何修改默认端口号的方法步骤
2019/07/12 Python
解决django 新增加用户信息出现错误的问题
2019/07/28 Python
Python Des加密解密如何实现软件注册码机器码
2020/01/08 Python
Python对象的属性访问过程详解
2020/03/05 Python
Python web如何在IIS发布应用过程解析
2020/05/27 Python
CSS3中的弹性布局em运用入门详解 1em等于多少像素
2021/02/08 HTML / CSS
联想德国官网:Lenovo Germany
2018/07/04 全球购物
XMLHttpRequest对象在IE和Firefox中创建方式有没有不同
2016/03/23 面试题
Java如何支持I18N?
2016/10/31 面试题
迟到检讨书900字
2014/01/14 职场文书
社区母亲节活动方案
2014/03/05 职场文书
2014年社团工作总结范文
2014/11/27 职场文书
开平碉楼导游词
2015/02/06 职场文书
农村老人去世追悼词
2015/06/23 职场文书
使用Redis实现实时排行榜功能
2021/07/02 Redis