js实现无限层级树形数据结构(创新算法)


Posted in Javascript onFebruary 27, 2020

由于做项目的需要,把一个线性数组转成树形数组,在网上查了很多文章,觉得他们写的太复杂了,于是自己写了一个,在折腾了一下午终于把它写出来啦(激动.gif),用两个filter过滤器就搞定了,代码简洁明了,数据结构小白都能看懂。

js代码:把扁平数据转成树形数据

function setTreeData(source){
  let cloneData = JSON.parse(JSON.stringify(source))   // 对源数据深度克隆
  return cloneData.filter(father=>{           // 循环所有项,并添加children属性
    let branchArr = cloneData.filter(child=> father.id == child.parentId);  // 返回每一项的子级数组
    branchArr.length>0 ? father.children=branchArr : ''  //给父级添加一个children属性,并赋值
    return father.parentId==0;   //返回第一层
  });
}

根据网友给我指出的问题,之前的算法会影响到源数据,之后我对获取的数据进行了深度克隆,完美解决。

封装函数:

function treeData(source, id, parentId, children){  
  let cloneData = JSON.parse(JSON.stringify(source))
  return cloneData.filter(father=>{
    let branchArr = cloneData.filter(child => father[id] == child[parentId]);
    branchArr.length>0 ? father[children] = branchArr : ''
    return father[parentId] == 0    // 如果第一层不是parentId=0,请自行修改
  })
}
 
// 调用时,字段名以字符串的形式传参,如treeData(source, 'id', 'parentId', 'children')

实例1:使用element-ui的组件制作一个树形多级嵌套伸缩菜单栏

实现效果:

js实现无限层级树形数据结构(创新算法)

vue组件:

<template>
 <el-tree
  :data="treeData"
  :props="defaultProps"
  accordion
  @node-click="handleNodeClick">
 </el-tree>
</template>
 
<script>
  export default {
    name: "Test",
   data(){
    return {
     data : [
      {id:1,parentId:0,name:"一级菜单A",rank:1},
      {id:2,parentId:0,name:"一级菜单B",rank:1},
      {id:3,parentId:0,name:"一级菜单C",rank:1},
      {id:4,parentId:1,name:"二级菜单A-A",rank:2},
      {id:5,parentId:1,name:"二级菜单A-B",rank:2},
      {id:6,parentId:2,name:"二级菜单B-A",rank:2},
      {id:7,parentId:4,name:"三级菜单A-A-A",rank:3},
      {id:8,parentId:7,name:"四级菜单A-A-A-A",rank:4},
      {id:9,parentId:8,name:"五级菜单A-A-A-A-A",rank:5},
      {id:10,parentId:9,name:"六级菜单A-A-A-A-A-A",rank:6},
      {id:11,parentId:10,name:"七级菜单A-A-A-A-A-A-A",rank:7},
      {id:12,parentId:11,name:"八级菜单A-A-A-A-A-A-A-A",rank:8},
      {id:13,parentId:12,name:"九级菜单A-A-A-A-A-A-A-A-A",rank:9},
      {id:14,parentId:13,name:"十级菜单A-A-A-A-A-A-A-A-A-A",rank:10},
     ],
     defaultProps: {
      children: 'children',
      label: 'name'
     }
    }
   },
   computed:{
    treeData(){
     let cloneData = JSON.parse(JSON.stringify(this.data))  // 对源数据深度克隆
     return cloneData.filter(father=>{        
      let branchArr = cloneData.filter(child=>father.id == child.parentId)  //返回每一项的子级数组
      branchArr.length>0 ? father.children = branchArr : ''  //如果存在子级,则给父级添加一个children属性,并赋值
      return father.parentId==0;   //返回第一层
     });
    }
   },
   methods:{
    handleNodeClick(data){
     // console.log(data)
     console.log(this.treeData)
    }
   },
   mounted(){
   }
  }
</script>
 
<style scoped>
 
</style>
Javascript 相关文章推荐
jquery模拟按下回车实现代码
Sep 20 Javascript
JS.elementGetStyle(element, style)应用示例
Sep 24 Javascript
Java框架SSH结合Easyui控件实现省市县三级联动示例解析
Jun 12 Javascript
15位和18位身份证JS校验的简单实例
Jul 18 Javascript
利用C/C++编写node.js原生模块的方法教程
Jul 07 Javascript
BootStrap模态框不垂直居中的解决方法
Oct 19 Javascript
详解Vue项目编译后部署在非网站根目录的解决方案
Apr 26 Javascript
微信小程序实现发送验证码按钮效果
Dec 20 Javascript
vue项目打包后上传至GitHub并实现github-pages的预览
May 06 Javascript
vue-week-picker实现支持按周切换的日历
Jun 26 Javascript
vue页面跳转实现页面缓存操作
Jul 22 Javascript
Vue实现摇一摇功能(兼容ios13.3以上)
Jan 26 Vue.js
js实现树形数据转成扁平数据的方法示例
Feb 27 #Javascript
vue学习笔记之给组件绑定原生事件操作示例
Feb 27 #Javascript
ElementUI Tree 树形控件的使用并给节点添加图标
Feb 27 #Javascript
ElementUI中el-tree节点的操作的实现
Feb 27 #Javascript
element el-tree组件的动态加载、新增、更新节点的实现
Feb 27 #Javascript
element-ui table行点击获取行索引(index)并利用索引更换行顺序
Feb 27 #Javascript
微信小程序录音实现功能并上传(使用node解析接收)
Feb 26 #Javascript
You might like
在php MYSQL中插入当前时间
2008/04/06 PHP
PHP 压缩文件夹的类代码
2009/11/05 PHP
CodeIgniter配置之autoload.php自动加载用法分析
2016/01/20 PHP
Laravel最佳分割路由文件(routes.php)的方式
2016/08/04 PHP
Yii2汉字转拼音类的实例代码
2017/04/18 PHP
BOOM vs RR BO3 第二场2.13
2021/03/10 DOTA
JavaScript OOP类与继承
2009/11/15 Javascript
JQuery获取浏览器窗口内容部分高度的代码
2012/02/24 Javascript
JavaScript中使用arguments获得函数传参个数实例
2014/08/27 Javascript
JavaScript link方法入门实例(给字符串加上超链接)
2014/10/17 Javascript
移除AngularJS下URL中的#字符的方法
2015/06/19 Javascript
jQuery实现网页抖动的菜单抖动效果
2015/08/07 Javascript
JavaScript中实现Map的示例代码
2015/09/09 Javascript
JS实现黑色大气的二级导航菜单效果
2015/09/18 Javascript
JS实现仿QQ效果的三级竖向菜单
2015/09/25 Javascript
VUEJS实战之构建基础并渲染出列表(1)
2016/06/13 Javascript
JS 实现Base64编码与解码实例详解
2016/11/07 Javascript
ES6新特性之函数的扩展实例详解
2017/04/01 Javascript
Angular实现响应式表单
2017/08/04 Javascript
chorme 浏览器记住密码后input黄色背景处理方法(两种)
2017/11/22 Javascript
JavaScript查看代码运行效率console.time()与console.timeEnd()用法
2019/01/18 Javascript
如何从头实现一个node.js的koa框架
2019/06/17 Javascript
python实现简单的TCP代理服务器
2014/10/08 Python
Python2.x中文乱码问题解决方法
2015/06/02 Python
python腾讯语音合成实现过程解析
2019/08/01 Python
Python私有属性私有方法应用实例解析
2020/09/15 Python
HTML5中的Web Notification桌面通知功能的实现方法
2019/07/29 HTML / CSS
俄罗斯最大的香水和化妆品网上商店:Randewoo
2020/11/05 全球购物
面向对象编程OOP的优点
2013/01/22 面试题
自动化工程专业个人应聘自荐信
2013/09/26 职场文书
企业职业病防治方案
2014/05/29 职场文书
服务理念口号
2014/06/11 职场文书
2015商场元旦促销活动策划方案
2014/12/09 职场文书
导游词范文之颐和园/重庆/云台山
2019/09/10 职场文书
redis实现排行榜功能
2021/05/24 Redis
spring boot中nativeQuery的用法
2021/07/26 Java/Android