js樹(shù)形結(jié)構(gòu)數(shù)據(jù)格式化

我們有時(shí)候會(huì)拿到一個(gè)包含p_id和id的類似樹(shù)形結(jié)構(gòu)的數(shù)據(jù),有一款jq插件zTree就有用到這樣的數(shù)據(jù)。比如:


假設(shè)第一個(gè)元素為a節(jié)點(diǎn),我們希望在a節(jié)點(diǎn)中加上children屬性,該屬性為數(shù)組類型,其元素為其他節(jié)點(diǎn)的p_id等于a節(jié)點(diǎn)的id的對(duì)象。

處理后的a節(jié)點(diǎn)為


處理這樣的數(shù)據(jù)我想到的是首先拿到一級(jí)節(jié)點(diǎn),之后再用遞歸去尋找一級(jí)節(jié)點(diǎn)的子節(jié)點(diǎn)。然后直接push到一級(jí)節(jié)點(diǎn)的children里就可以了。

這里我用的vue 做測(cè)試:

待處理數(shù)據(jù)為areaArr,也就是上面截圖的areaArr,之后寫兩個(gè)方法,a,b。a方法中拿到一級(jí)節(jié)點(diǎn),然后調(diào)用b方法拿到一級(jí)節(jié)點(diǎn)的子節(jié)點(diǎn)。

其中字節(jié)點(diǎn)可能還有子節(jié)點(diǎn),所以b方法中使用遞歸查找子節(jié)點(diǎn)。


結(jié)果為:


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容