转树形结构、遍历树形结构、扁平树形

这篇就是写一下平级结构与树形结构之间的转化,之前也有写过类似的:
对象数组转为树形结构
js树形结构,根据里层id找出它所属的每层父级集合
大家有兴趣可以去看一下,也算是简单巩固一下js吧

1. 对象数组转为树形结构 

一般如果平级的数组结构可以转化为树形,都会有id和parentId两个字段来标识子级和父级,来确定关系

 不说闲话了直接上方法:

function toTree(list, pid = 'parentId', childrenKey = 'children') {
  const target = []
  const map = {}
  list.forEach(item => {
    map[item.id] = item
  })
  list.forEach(item => {
    let parent = map[item[pid]]
    if (parent) {
      (parent[childrenKey] || (parent[childrenKey] = [])).push(item)
    } else {
      target.push(item)
    }
  })
  return target
}

2. 遍历树形结构、扁平树形 

就是我们现在有个树形结构,如何遍历到整个树形的每一项呢,也同样的肯定会有个标识子节点的属性,例如:children,然后我们可以通过递归和forEach方法即可遍历整个树形,为了更方便起见,我们可以传递一个callback回调函数,这样遍历到每个节点的时候可以更方便的写一些自己的逻辑,就像forEach似的,工具函数如下:

function mapTree(treeData, callback, childrenKey = 'children', level = 0) {
  treeData.forEach(item => {
    const curItem = JSON.parse(JSON.stringify(item))
    curItem.level = level
    callback(curItem, treeData)
    if(item?.[childrenKey]?.length) {
      mapTree(item[childrenKey], callback, childrenKey, level + 1)
    }
  })
}

这里举个例子:就是我们想扁平整个树形,就可以使用上面的工具方法 

let list = []
mapTree(tree, item => {
  if(item.children) delete item.children
  list.push(item)
})
console.log(list)

3. 测试数据: 

对象数组 

let source = [
  {
    title: '角色编辑',
    parentId: 22,
    id: 222,
  },
  {
    title: '系统管理',
    parentId: 0,
    id: 1,
  },
  {
    title: '角色新增',
    parentId: 22,
    id: 221,
  },
  {
    title: '角色删除',
    parentId: 22,
    id: 223,
  },
  {
    title: '用户新增',
    parentId: 33,
    id: 331,
  },
  {
    title: '菜单新增',
    parentId: 11,
    id: 111,
  },
  {
    title: '菜单编辑',
    parentId: 11,
    id: 112,
  },
  {
    title: '用户管理',
    parentId: 0,
    id: 33,
  },
  {
    title: '菜单管理',
    parentId: 1,
    id: 11,
  },
  {
    title: '菜单删除',
    parentId: 11,
    id: 113,
  },
  {
    title: '用户编辑',
    parentId: 33,
    id: 332,
  },
  {
    title: '角色管理',
    parentId: 1,
    id: 22,
  },
  {
    title: '用户删除',
    parentId: 33,
    id: 333,
  }
]

树形数据 

let tree = [
  {
    "title": "系统管理",
    "parentId": 0,
    "id": 1,
    "children": [
      {
        "title": "菜单管理",
        "parentId": 1,
        "id": 11,
        "children": [
          {
            "title": "菜单新增",
            "parentId": 11,
            "id": 111
          },
          {
            "title": "菜单编辑",
            "parentId": 11,
            "id": 112
          },
          {
            "title": "菜单删除",
            "parentId": 11,
            "id": 113
          }
        ]
      },
      {
        "title": "角色管理",
        "parentId": 1,
        "id": 22,
        "children": [
          {
            "title": "角色编辑",
            "parentId": 22,
            "id": 222
          },
          {
            "title": "角色新增",
            "parentId": 22,
            "id": 221
          },
          {
            "title": "角色删除",
            "parentId": 22,
            "id": 223
          }
        ]
      }
    ]
  },
  {
    "title": "用户管理",
    "parentId": 0,
    "id": 33,
    "children": [
      {
        "title": "用户新增",
        "parentId": 33,
        "id": 331
      },
      {
        "title": "用户编辑",
        "parentId": 33,
        "id": 332
      },
      {
        "title": "用户删除",
        "parentId": 33,
        "id": 333
      }
    ]
  }
]

你可能感兴趣的:(javascript,前端,javascript)