首先假設(shè)有一個樹形結(jié)構(gòu)數(shù)據(jù)如下
var tree=[
{
'id': '1',
'name': '教學(xué)素材管理',
'children':[
{
'id': '101',
'name': '教學(xué)素材',
'children':[
{
'id': '10101',
'name': '修改',
},
{
'id': '10102',
'name': '添加',
}
]
}, {
'id': '102',
'name': '測試試題',
},
{
'id': '103',
'name': '問題任務(wù)',
}
]
}, {
'id': '2',
'name': '基礎(chǔ)數(shù)據(jù)管理',
'children':[
{
'id': '201',
'name': '專業(yè)設(shè)置',
},
{
'id': '202',
'name': '專業(yè)管理',
}
]
}
]
1、如何在tree中找到id=10102的對象?
思路一:深度遍歷,從頂點開始,當(dāng)前節(jié)點有子節(jié)點則遍歷當(dāng)前節(jié)點的子節(jié)點(遞歸)。
function deepQuery(tree,id) {
var isGet = false;
var retNode = null;
function deepSearch(tree,id){
for(var i = 0; i<tree.length; i++) {
if(tree[i].children && tree[i].children.length>0) {
deepSearch(tree[i].children,id);
}
if(id === tree[i].id || isGet) {
isGet||(retNode = tree[i]);
isGet = true;
break;
}
}
}
deepSearch(tree,id);
return retNode;
}
var getNode = deepQuery(tree,10102);
console.log(getNode)
思路二:廣度遍歷,遍歷根節(jié)點的所有子節(jié)點,再從第一個子節(jié)點開始依次遍歷。
function breadthQuery(tree, id) {
var stark = [];
stark = stark.concat(tree);
while(stark.length) {
var temp = stark.shift();
if(temp.children) {
stark = stark.concat(temp.children);
}
if(temp.id === id) {
return temp;
}
}
}
var getNode=breadthQuery(tree,10102);
console.log(getNode);
2、如何將樹形結(jié)構(gòu)轉(zhuǎn)換為有父子關(guān)系屬性的數(shù)組結(jié)構(gòu)?
思路一:初始化一個空數(shù)組,從tree的頂端開始遍歷,當(dāng)前節(jié)點有子節(jié)點時,一邊繼續(xù)遍歷子節(jié)點,一邊在當(dāng)前節(jié)點上刪除子節(jié)點,將當(dāng)前節(jié)點push到空數(shù)組。
function flatten1(tree) {
var arr = [];
function spread(tree,pid) {
for (var i=0; i < tree.length; i++ ) {
item = tree[i]
let {id,name}=item;
arr.push({id,name,pid})
if (item.children) {
spread(item.children,item.id)
delete item.children
}
}
}
spread(tree,0)
return arr;
}
var newArr = flatten1(tree);
思路二:
function flatten2 (data,pid) {
return data.reduce((arr, {id, name, children = []}) =>
arr.concat([{id, name,pid}], flatten2(children,id)), [])
}
var newArr = flatten2(tree,0);

image.png
3、如何將數(shù)組結(jié)構(gòu)轉(zhuǎn)換為樹形結(jié)構(gòu)?
function treeData(data){
let cloneData = JSON.parse(JSON.stringify(data))
return cloneData.filter(father=>{
let branchArr = cloneData.filter(child => father['id'] == child['pid']);
branchArr.length>0 ? father['children'] = branchArr : '';
return father['pid'] == 0 ;
})
}
var newTree = treeData(newArr)

image.png