国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

javascript - js寫一個(gè)遞歸把數(shù)據(jù)結(jié)構(gòu)重組成另外的結(jié)構(gòu)

瀏覽:187日期:2023-05-01 11:22:51

問(wèn)題描述

現(xiàn)在有以下數(shù)據(jù)結(jié)構(gòu):

[{ id: 1, pid: 0, name: '年級(jí)'}, { id: 2, pid: 1, name: '一年級(jí)'}, { id: 3, pid: 1, name: '二年級(jí)'}, { id: 4, pid: 0, name: '專業(yè)'}, { id: 5, pid: 4, name: '單片機(jī)開發(fā)'}]

寫一個(gè)JS方法,將其轉(zhuǎn)換成以下格式數(shù)據(jù):

[{ id: 1, pid: 0, name: '年級(jí)', children: [{id: 2,pid: 1,name: '一年級(jí)' }, {id: 3,pid: 1,name: '二年級(jí)' }]}, { id: 4, pid: 0, name: '專業(yè)', children: [{id: 5,pid: 4,name: '單片機(jī)開發(fā)' }]}]

問(wèn)題解答

回答1:

var list = [{ id: 1, pid: 0, name: '年級(jí)'}, { id: 2, pid: 1, name: '一年級(jí)'}, { id: 3, pid: 1, name: '二年級(jí)'}, { id: 4, pid: 0, name: '專業(yè)'}, { id: 5, pid: 4, name: '單片機(jī)開發(fā)'}];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: '年級(jí)' }, { id: 2, pid: 1, name: '一年級(jí)' }, { id: 3, pid: 1, name: '二年級(jí)' }, { id: 4, pid: 0, name: '專業(yè)' }, { id: 5, pid: 4, name: '單片機(jī)開發(fā)' }];// 生成查找表,可以按 id 查到節(jié)點(diǎn)const dict = list.reduce((all, item) => { all[item.id] = item; return all;}, {});// 由于原始數(shù)據(jù)沒(méi)有 id 為 0 的根節(jié)點(diǎn),// 這里模擬一個(gè),最終它的 children 就是實(shí)際的所有根節(jié)點(diǎn)var root = { id: 0};dict[0] = root;// 循環(huán)添加關(guān)系list.forEach(item => { const parent = dict[item.pid]; // 確保父節(jié)點(diǎn)的 children 存在 parent.children = parent.children || []; parent.children.push(item);});// 輸出結(jié)果 root.children// 注意,root 不是結(jié)果,root.children 才是console.log(JSON.stringify(root.children, null, 4));

javascript - js寫一個(gè)遞歸把數(shù)據(jù)結(jié)構(gòu)重組成另外的結(jié)構(gòu)

回答3:

參考一下

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}, [])

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 苍溪县| 闸北区| 建瓯市| 凤阳县| 周宁县| 苏尼特左旗| 陆良县| 高尔夫| 济源市| 桂阳县| 丹江口市| 竹北市| 彭水| 奉新县| 松阳县| 云梦县| 襄樊市| 沧州市| 吴忠市| 金溪县| 巫山县| 东乌珠穆沁旗| 平度市| 滨州市| 教育| 华宁县| 武平县| 闵行区| 翁源县| 罗平县| 石棉县| 垣曲县| 游戏| 青河县| 岐山县| 宣恩县| 房产| 多伦县| 玉溪市| 楚雄市| 蒙阴县|