簡體   English   中英

在javascript中的父子關系排序

[英]parent child relation sorting in javascript

我有以下結構

[
    {
         "category_id" : 1,
         "parent_category" : null
    } ,
    {
         "category_id" : 2,
         "parent_category" : 1
    },
    {
         "category_id" : 3,
         "parent_category" : 1
    },
    {
         "category_id" : 4,
         "parent_category" : 2
    },
    ,
    {
         "category_id" : 5,
         "parent_category" : null
    },
    ,
    {
         "category_id" : 6,
         "parent_category" : 5
    }


]

所以我有父子關系,我想用以下結構對它進行排序

[
    {
      "parent_category":[ "array of all children that follow this main parent category" ]  
    },
    {},
    {}
]

我已經看到很多解決方案,但所有關於樹結構輸出

謝謝

你可以嘗試這個解決方案。

let json = [
    { id : 1, name : 'A', parent : 0 },
    { id : 2, name : 'B', parent : 0 },
    { id : 3, name : 'C', parent : 1 },
    { id : 4, name : 'D', parent : 2 },
    { id : 5, name : 'E', parent : 1 },
    { id : 6, name : 'F', parent : 2 },
    { id : 7, name : 'G', parent : 0 },
];

//collecting all parents (whose parent is 0)
let parents = json.filter(x => x.parent === 0);

//collecting all chlidren (whose parent is not 0)
let children = json.filter(x => x.parent !== 0);

//iterating through children and pushing it to **parents** json just below the parent
for(x of children){
    let index = parents.findIndex(obj => obj.id === x.parent);
    parents.splice(index+1, 0, x);
}

現在父母 json根據父母對象進行排序。

parents:
   [ { id: 1, name: 'A', parent: 0 },
     { id: 5, name: 'E', parent: 1 },
     { id: 3, name: 'C', parent: 1 },
     { id: 2, name: 'B', parent: 0 },
     { id: 6, name: 'F', parent: 2 },
     { id: 4, name: 'D', parent: 2 },
     { id: 7, name: 'G', parent: 0 } ]

希望這會有所幫助。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM