国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

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

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

問題描述

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

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

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

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

問題解答

回答1:

var list = [{ id: 1, pid: 0, name: '年級'}, { id: 2, pid: 1, name: '一年級'}, { id: 3, pid: 1, name: '二年級'}, { 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: '年級' }, { id: 2, pid: 1, name: '一年級' }, { id: 3, pid: 1, name: '二年級' }, { 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ù)沒有 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)文章:
主站蜘蛛池模板: 91精品久久久久久久久网影视 | 韩国一级理黄论片 | 日韩精品一区二区三区在线观看 | 新婚第一次一级毛片 | 91香蕉国产观看免费人人 | 免费观看欧美成人h | 欧美视频亚洲视频 | 久久精品国内一区二区三区 | 国产tv在线观看 | 国产精品一二三区 | 亚洲乱人伦精品图片 | 国产专区一va亚洲v天堂 | 奇米色88欧美一区二区 | 正在播放国产大学生情侣 | 久久久久久久久久免免费精品 | 六月丁香久久丫 | 久久er热在这里只有精品85 | 欧美午夜不卡在线观看最新 | 久久w5ww成w人免费不卡 | 欧美成人aaaa免费高清 | 国产区高清| 亚洲天堂一区二区在线观看 | 国产成人无精品久久久久国语 | 国产一区二区三区不卡免费观看 | 国产精品视频成人 | 国产美女一区二区三区 | 亚洲精品一区亚洲精品 | 午夜私人影院免费体验区 | 国产高清在线观看视频手机版 | 毛色毛片免费观看 | 青青爽国产手机在线观看免费 | 中文字幕在线视频网 | 日本韩国欧美在线 | 免费 欧美 自拍 在线观看 | 国产a一级毛片含羞草传媒 国产a自拍 | 国产思思 | 一级毛片在线免费播放 | 国产片自拍| 亚洲国产精品网站久久 | 久久福利青草精品资源站免费 | 成人女人a毛片在线看 |