zoukankan      html  css  js  c++  java
  • 关于把一维数据通过id和parentId之间的联系转化为多维的树形结构数据

    关于把一维数据通过id和parentId之间的联系转化为多维的树形结构数据

      1 // 原始数据结构
      2 var resourceData = {
      3   "id": 6373341721883527000,
      4   "name": "客户商机管理",
      5   "icon": "cap-icon-wenjianjia",
      6   "items": [
      7     {
      8       "id": 15622066496240,
      9       "name": "项目策划",
     10       "icon": "cap-icon-wenjianjia",
     11       "parentId": 6373341721883527000,
     12       "target": "newWindow",
     13       "url": "/seeyon/cap4/businessTemplateController.do?method=capUnflowList&srcFrom=bizconfig&businessId=-6426420947780546777&moduleId=2267110360249484669&formId=2677227718149229873&type=baseInfo&tag=1563413336253"
     14     },
     15     {
     16       "id": 156220664962401,
     17       "name": "项目任务书",
     18       "icon": "cap-icon-wenjianjia",
     19       "parentId": 15622066496240,
     20       "target": "newWindow",
     21       "url": "/seeyon/cap4/businessTemplateController.do?method=capUnflowList&srcFrom=bizconfig&businessId=-6426420947780546777&moduleId=2267110360249484669&formId=2677227718149229873&type=baseInfo&tag=1563413336253"
     22     },
     23     {
     24       "id": 156220664962402,
     25       "name": "设计大纲编制",
     26       "icon": "cap-icon-wenjianjia",
     27       "parentId": 15622066496240,
     28       "target": "newWindow",
     29       "url": "/seeyon/cap4/businessTemplateController.do?method=capUnflowList&srcFrom=bizconfig&businessId=-6426420947780546777&moduleId=2267110360249484669&formId=2677227718149229873&type=baseInfo&tag=1563413336253"
     30     },
     31     {
     32       "id": 156220664962403,
     33       "name": "OBS策划",
     34       "icon": "cap-icon-wenjianjia",
     35       "parentId": 15622066496240,
     36       "target": "newWindow",
     37       "url": "/seeyon/cap4/businessTemplateController.do?method=capUnflowList&srcFrom=bizconfig&businessId=-6426420947780546777&moduleId=2267110360249484669&formId=2677227718149229873&type=baseInfo&tag=1563413336253"
     38     },
     39     {
     40       "id": 1562206649624031,
     41       "name": "项目总览",
     42       "icon": "cap-icon-wenjianjia",
     43       "parentId": 156220664962403,
     44       "target": "newWindow",
     45       "url": "/seeyon/cap4/businessTemplateController.do?method=capUnflowList&srcFrom=bizconfig&businessId=-6426420947780546777&moduleId=2267110360249484669&formId=2677227718149229873&type=baseInfo&tag=1563413336253"
     46     },
     47     {
     48       "id": 15622066496240311,
     49       "name": "项目概述",
     50       "icon": "cap-icon-wenjianjia",
     51       "parentId": 1562206649624031,
     52       "target": "newWindow",
     53       "url": "/seeyon/cap4/businessTemplateController.do?method=capUnflowList&srcFrom=bizconfig&businessId=-6426420947780546777&moduleId=2267110360249484669&formId=2677227718149229873&type=baseInfo&tag=1563413336253"
     54     },
     55     {
     56       "id": 15622066496200,
     57       "name": "项目执行",
     58       "icon": "cap-icon-wenjianjia",
     59       "parentId": 6373341721883527000,
     60       "target": "newWindow",
     61       "url": "/seeyon/cap4/businessTemplateController.do?method=capUnflowList&srcFrom=bizconfig&businessId=-6426420947780546777&moduleId=2267110360249484669&formId=2677227718149229873&type=baseInfo&tag=1563413336253"
     62     },
     63     {
     64       "id": 15622066496201,
     65       "name": "项目完成率",
     66       "icon": "cap-icon-wenjianjia",
     67       "parentId": 6373341721883527000,
     68       "target": "newWindow",
     69       "url": "/seeyon/cap4/businessTemplateController.do?method=capUnflowList&srcFrom=bizconfig&businessId=-6426420947780546777&moduleId=2267110360249484669&formId=2677227718149229873&type=baseInfo&tag=1563413336253"
     70     },
     71     {
     72       "id": 15622066496202,
     73       "name": "管理控制",
     74       "icon": "cap-icon-wenjianjia",
     75       "parentId": 6373341721883527000,
     76       "target": "newWindow",
     77       "url": "/seeyon/cap4/businessTemplateController.do?method=capUnflowList&srcFrom=bizconfig&businessId=-6426420947780546777&moduleId=2267110360249484669&formId=2677227718149229873&type=baseInfo&tag=1563413336253"
     78     },
     79     {
     80       "id": 156220664962011,
     81       "name": "测试",
     82       "icon": "cap-icon-wenjianjia",
     83       "parentId": 15622066496201,
     84       "target": "newWindow",
     85       "url": "/seeyon/cap4/businessTemplateController.do?method=capUnflowList&srcFrom=bizconfig&businessId=-6426420947780546777&moduleId=2267110360249484669&formId=2677227718149229873&type=baseInfo&tag=1563413336253"
     86     },
     87     {
     88       "id": 1562206649620111,
     89       "name": "子测试1",
     90       "icon": "cap-icon-wenjianjia",
     91       "parentId": 156220664962011,
     92       "target": "newWindow",
     93       "url": "/seeyon/cap4/businessTemplateController.do?method=capUnflowList&srcFrom=bizconfig&businessId=-6426420947780546777&moduleId=2267110360249484669&formId=2677227718149229873&type=baseInfo&tag=1563413336253"
     94     }
     95   ]
     96 };
     97 // 需要处理的数据是resourceData的items数组,单独抽离出来
     98 var datas = resourceData.items;
     99 // 先找到顶层数据
    100 var parents = datas.filter(item => item.parentId === resourceData.id);
    101 // 再找到子层数据
    102 var children = datas.filter(item => item.parentId !== resourceData.id);
    103 // 写一个方法,通过id和parentId多维化子层数据
    104 function transtor(parents, children) {
    105     if(parents && parents.length) {
    106         // 遍历顶层数据
    107         parents.forEach((parent) => {
    108             // 遍历子层数据
    109             children.forEach((currentChild, index) => {
    110                 if(currentChild.parentId === parent.id){
    111                     // 深拷贝一份,保证循环遍历
    112                     var tempChildren = JSON.parse(JSON.stringify(children));
    113                     // 如果子层数据的当前子项currentChild的parentId与当前的顶层数据parent的id相同,则currentChild是parent的子元素
    114                     // 1.删除临时子层数据的当前项,防止后面的递归循环重复遍历
    115                     tempChildren.splice(index, 1);
    116                     // 2.递归,把子层数据当前的子元素currentChild放进数组作为第一个参数,即为新的父元素,把新的临时子层数据作为第二个参数,即为新的子元素
    117                     transtor([currentChild], tempChildren);
    118                     // 3.判断
    119                     // 如果第一层元素的当前子项parent的children存在,那么把子层数据的当前子项currentChild push进去
    120                     if(typeof parent.children !== "undefined"){
    121                         parent.children.push(currentChild);
    122                     }else{
    123                         // 如果第一层元素的当前子项parent的children不存在,就给他加一个children属性,并赋值为[currentChild]
    124                         parent.children = [currentChild];
    125                     }
    126                 }
    127             })
    128         })
    129     }
    130 };
    131 transtor(parents, children);
    132 var treedata = parents;

    打印结果:

  • 相关阅读:
    通过运用CSS框架学到了什么
    浏览器判断一览表
    默认样式表之HTML4
    MooTools 1.4 源码分析 -overloadSetter
    MooTools 1.4 源码分析
    MooTools 1.4 源码分析
    javascript一些底层方法总结及用法
    viewport移动端适配,读文笔记
    vue获取v-model数据类型boolean改变成string
    contextify::ContextifyScript::New(const v8::FunctionCallbackInfo<v8::Value>&):
  • 原文地址:https://www.cnblogs.com/lindang/p/14435007.html
Copyright © 2011-2022 走看看