将以下结构的数据转成数组。
1const listTree = [ 2 { 3 id: 1, 4 name: '部门1', 5 pid: 0, 6 children: [ 7 { 8 id: 2, 9 name: '部门1-1', 10 pid: 1, 11 children: [ 12 { 13 id: 4, 14 name: '部门1-1-1', 15 pid: 2, 16 children: [] 17 } 18 ] 19 }, 20 { 21 id: 3, 22 name: '部门1-2', 23 pid: 1, 24 children: [ 25 { 26 id: 5, 27 name: '部门1-2-1', 28 pid: 3, 29 children: [] 30 } 31 ] 32 } 33 ] 34 }, 35 { 36 id: 6, 37 name: '部门2', 38 pid: 0, 39 children: [ 40 { 41 id: 7, 42 name: '部门2-1', 43 pid: 6, 44 children: [] 45 } 46 ] 47 }, 48 { 49 id: 8, 50 name: '部门3', 51 pid: 0, 52 children: [] 53 } 54]
期望结果:
1const list = [ 2 {id: 1, name: '部门1', pid: 0}, 3 {id: 2, name: '部门1-1', pid: 1}, 4 {id: 3, name: '部门1-2', pid: 1}, 5 {id: 4, name: '部门1-1-1', pid: 2}, 6 {id: 5, name: '部门1-2-1', pid: 3}, 7 {id: 6, name: '部门2', pid: 0}, 8 {id: 7, name: '部门2-1', pid: 6}, 9 {id: 8, name: '部门3', pid: 0}, 10]
参考答案:
1function treeTransList(tree, key) { 2 return tree.reduce(function(con, item) { 3 var callee = arguments.callee; 4 con.push(item); 5 if (item[key] && item[key].length >0) 6 item[key].reduce(callee, con); 7 return con; 8 }, []).map(function(item){ 9 item[key] = []; 10 return item; 11 }) 12} 13treeTransList(listTree, 'children')
1function getItem(tree, result) { 2 for (let i = 0; i < tree.length; i++) { 3 if(tree[i].children) { 4 getItem(tree[i].children, result) 5 delete tree[i].children; 6 } 7 result.push(tree[i]) 8 } 9 return result; 10} 11 12function treeToList(tree) { 13 const result = []; 14 getItem(tree, result); 15 return result; 16} 17treeToList(listTree)
1function treeToList(tree, childName = 'children') { 2 // 设置临时数组,用来存放队列 3 let queen = []; 4 // 设置输出数组,用来存放要输出的一维数组 5 const result = []; 6 queen = queen.concat(tree); 7 // 对树对象进行广度优先的遍历 8 while(queen.length) { 9 const first = queen.shift(); 10 if (first[childName]) { 11 queen = queen.concat(first[childName]); 12 delete first[childName] 13 } 14 result.push(first); 15 } 16 return result; 17} 18treeToList(listTree, 'children')
最近更新时间:2023-08-20