如何從樹結構有效率地建構樹
P粉345302753
P粉345302753 2024-03-28 13:53:08
0
1
437

我有一堆樹結構中的物件。但目前這個結構對我來說不起作用,因為我需要使用v-teeview,所以我需要重新建構它......

我的樹狀結構目前是這樣的:

items: [
  {
    data: [
      { ... },
    ],
    children: [],
  },
  {
    data: [{ ... }],
    children: [{...}, {...}]
   }
] 

我需要重組類似的東西:

  items: [
      {     
         id: 76,
         name: "ADIS ",
         children: [],
      },
      {
        id: 64,
        name: "YSVERIS",
        children: [
          {
            id: 85,
            name: "MERCEDES",
            children: [],
          },
          {
            id: 83,
            name: "YNGRIBEL",  
            children: [],
          },
        ],
      }
    ]

所以,我實作了一個遞歸函數,這個函數是為了重構樹。

codesandbox 中的程式碼:

export default {
  methods: {
    createTree(items) {
      items.forEach((element) => {
        if (element.children.length === 0) {
          this.datatree.push({
            id: element.data[0].id,
            name: element.data[0].name,
            children: [],
          });
        } else {
          this.datatree.push({
            id: element.data[0].id,
            name: element.data[0].name,
            children: this.createTree(element.children),
          });
        }
      });
      console.log("root: ", this.datatree);
    },
  },
  mounted() {
    this.createTree(this.items);
  },
}

所以我目前的問題是,當我建立新樹時,它的子樹未定義,我做錯了什麼?

在我的範例程式碼中,我使用 console.log() 來查看新樹

P粉345302753
P粉345302753

全部回覆(1)
P粉401901266

createTree() 不傳回任何內容,因此將傳回值指派給 children 只會使 children 具有 undefined 值。

一種解決方案是遞歸呼叫輔助方法(例如,名為「createNode」),該方法從每個陣列元素建立樹節點(而不是遞歸呼叫createTree())。傳回createTree()的結果,並將傳回值賦給datatree

function createTree(items) {
  const createNode = ({ data, children }) => ({
    ...data[0],
    children: children?.map(child => createNode(child))
  })
  return items.map(item => createNode(item))
}

// MyComponent.vue
export default {
  mounted() {
    this.datatree = createTree(this.items)
  }
}

示範

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板