php陣列轉樹狀結構的方法:1、建立一個PHP範例檔案;2、建構一個函數,語法為「function buildTree(array $elements, $parentId = 0)」參數1是待轉換的數組,參數2則是指定的根節點;3、函數內定義$branch空數組用於存儲樹狀結構並進行遍歷;4、遍歷後將修改後的元素添加到$branch數組中,返回樹狀結構數組$branch即可。
本教學作業系統:Windows10系統、php8.1.3版本、Dell G3電腦。
將 PHP 陣列轉換為樹狀結構,可以透過遞歸方法實現。
下面是一個PHP 函數範例:
function buildTree(array $elements, $parentId = 0) { $branch = array(); foreach ($elements as $element) { if ($element['parent_id'] == $parentId) { $children = buildTree($elements, $element['id']); if ($children) { $element['children'] = $children; } $branch[] = $element; } } return $branch; }
在這個函數中,參數$elements 是待轉換的數組,$parentId 則是指定的根節點(預設為0) 。函數首先定義一個名為 $branch 的空數組用於儲存樹狀結構並進行遍歷。
在每次循環內,函數會檢查目前元素是否具有指定父 ID,如果是,則表示它是目前節點的子節點。然後呼叫自身的 buildTree() 函數來新增子節點,並將子節點指派給 $children 變數。函數繼續判斷 $children 是否為空,如果不是,將子節點賦值給當前元素的 'children' 鍵。最後,函數將修改後的元素加入到 $branch 陣列中。
當所有元素處理完畢後,函數會傳回樹狀結構陣列 $branch。
假設我們有以下資料:
$elements = [ ['id' => 1, 'name' => 'Parent 1', 'parent_id' => 0], ['id' => 2, 'name' => 'Child 1', 'parent_id' => 1], ['id' => 3, 'name' => 'Grandchild 1', 'parent_id' => 2], ['id' => 4, 'name' => 'Grandchild 2', 'parent_id' => 2], ['id' => 5, 'name' => 'Parent 2', 'parent_id' => 0], ];
可以呼叫該函數產生樹狀結構。
以上是php數組如何轉換成樹狀結構的詳細內容。更多資訊請關注PHP中文網其他相關文章!