javascript - js寫一個遞歸把數據結構重組成另外的結構
問題描述
現在有以下數據結構:
[{ id: 1, pid: 0, name: '年級'}, { id: 2, pid: 1, name: '一年級'}, { id: 3, pid: 1, name: '二年級'}, { id: 4, pid: 0, name: '專業'}, { id: 5, pid: 4, name: '單片機開發'}]
寫一個JS方法,將其轉換成以下格式數據:
[{ id: 1, pid: 0, name: '年級', children: [{id: 2,pid: 1,name: '一年級' }, {id: 3,pid: 1,name: '二年級' }]}, { id: 4, pid: 0, name: '專業', children: [{id: 5,pid: 4,name: '單片機開發' }]}]
問題解答
回答1:var list = [{ id: 1, pid: 0, name: '年級'}, { id: 2, pid: 1, name: '一年級'}, { id: 3, pid: 1, name: '二年級'}, { id: 4, pid: 0, name: '專業'}, { id: 5, pid: 4, name: '單片機開發'}];function parseList (list) { var map = {}; list.forEach(function (item) {if (!map[item.id]) { map[item.id] = item; } }); list.forEach(function (item) {if (item.pid != 0) { map[item.pid].chidren ? map[item.pid].chidren.push(item) : map[item.pid].chidren = [item];} }); return list.filter(function (item) {return item.pid === 0; });}var newList = parseList(list);回答2:
var list = [ { id: 1, pid: 0, name: '年級' }, { id: 2, pid: 1, name: '一年級' }, { id: 3, pid: 1, name: '二年級' }, { id: 4, pid: 0, name: '專業' }, { id: 5, pid: 4, name: '單片機開發' }];// 生成查找表,可以按 id 查到節點const dict = list.reduce((all, item) => { all[item.id] = item; return all;}, {});// 由于原始數據沒有 id 為 0 的根節點,// 這里模擬一個,最終它的 children 就是實際的所有根節點var root = { id: 0};dict[0] = root;// 循環添加關系list.forEach(item => { const parent = dict[item.pid]; // 確保父節點的 children 存在 parent.children = parent.children || []; parent.children.push(item);});// 輸出結果 root.children// 注意,root 不是結果,root.children 才是console.log(JSON.stringify(root.children, null, 4));
參考一下
var sortedData = data.reduce((result, item) => { result[item.id] = Object.assign({}, item) return result}, [])var result = sortedData.reduce((result, item) => { if (item.pid === 0) { result.push(item) } else { if (sortedData[item.pid].children) { sortedData[item.pid].children.push(item) } else { sortedData[item.pid].children = [item] } } return result}, [])
相關文章:
1. python - Django 表單問題?2. mysql - sql 語句更改表結構,添加多個列,怎么寫?3. 如何修改phpstudy的phpmyadmin放到其他地方4. javascript - 網頁中嵌套iframe,網頁和iframe viewport不同,怎么能讓iframe中的網頁不變形5. 關于Mysql聯合查詢6. css3 - 這個右下角折角用css怎么畫出來?7. javascript - 百度搜索網站,如何讓搜索結果顯示一張圖片加上一段描述,如圖;求教8. javascript - main head .intro-text{width:40%} main head{display:flex}為何無效?9. pip安裝提示Twisted錯誤問題(Python3.6.4安裝Twisted錯誤)10. 索引 - 請教下Mysql大數據量的聯合查詢
