將arr轉(zhuǎn)換為tree結(jié)構(gòu)2種方式

1.包array-to-tree

import arrayToTree from 'array-to-tree'
export function transArray(arr){
   return  arrayToTree(arr,{
     parentProperty: 'parentId',  //指向父節(jié)點(diǎn)的屬性名稱,默認(rèn)"parend_id"
     childrenProperty:'arrs'  //存儲(chǔ)子節(jié)點(diǎn)的屬性名稱,默認(rèn)"children"
     customID: 'Id' //唯一節(jié)點(diǎn)標(biāo)識(shí)符,默認(rèn)"id"
   })
}

2.字典映射

  let arr = [ 
         { Id: 1, name: '數(shù)據(jù)1', parentId: null },
         { Id: 2, name: '數(shù)據(jù)1-1', parentId: 1 },
         { Id: 3, name: '數(shù)據(jù)1-1-1', parentId: 2 },
         { Id: 4, name: '數(shù)據(jù)1-2', parentId: 1 }, 
         { Id: 5, name: '數(shù)據(jù)2', parentId: null }, 
         { Id: 6, name: '數(shù)據(jù)2-1', parentId: 5 }
      ]
  function toTree(arg){
     const newArr = [];
     const map = {} //存儲(chǔ)映射關(guān)系
     arg.forEach(item=>{
         if(!item.children){
             item.children = []
         }
        map[item.Id] = item
     })
     arg.forEach(item=>{
         if(item.parentId){
           map[item.parentId].children.push(item)
         }else{
           newArr.push(item)
         }
     })
    return newArr
  }
toTree(arr)
?著作權(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)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

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

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