您好,登錄后才能下訂單哦!
本文小編為大家詳細介紹“php無限極分類數組如何放”,內容詳細,步驟清晰,細節處理妥當,希望這篇“php無限極分類數組如何放”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。
遞歸方式
遞歸方式是php無限極分類數組中最常用的方式,它依靠函數的遞歸調用實現分類數據的構建。
遞歸方式的寫法如下:
/** * 無限極分類 * @param array $data 分類數據 * @param int $pid 父ID * @param int $level 層級數 * @return array 分類數組 */ function getTree($data, $pid = 0, $level = 0) { $tree = []; foreach ($data as $val) { if ($val['parent_id'] == $pid) { $val['level'] = $level; $val['children'] = getTree($data, $val['id'], $level + 1); $tree[] = $val; } } return $tree; }
以上代碼中,getTree函數接收三個參數,分別是分類數據$ data、父ID $ pid和層級數$ level。該函數首先創建一個$ tree數組,然后遍歷分類數據,如果當前分類項的父ID等于$ pid,則將其加入$ tree數組。每個分類項都會增加一個level屬性,表示當前層級數。同時,getTree函數會遞歸調用自己,讓子分類數組作為參數傳入,從而使得子分類項也能按照相同的方式處理。
循環方式
循環方式是另一種php無限極分類數組中的處理方式,它主要通過循環嵌套來實現分類數據的構建。
循環方式的寫法如下:
/** * 無限極分類 * @param array $data 分類數據 * @return array 分類數組 */ function getTree($data) { $tree = []; $node = []; foreach ($data as $val) { $node[$val['id']] = $val; } foreach ($node as $key => &$val) { if (isset($node[$val['parent_id']])) { $node[$val['parent_id']]['children'][] = &$val; } else { $tree[] = &$val; } } return $tree; }
以上代碼中,getTree函數接收一個參數$ data,表示分類數據。該函數首先創建一個$ tree數組和一個$ node數組,并將$ data數據放入$ node數組中。接著,foreach循環遍歷$ node數組,如果當前分類項的父ID在$ node數組中,則將當前分類項加入該父分類項的children子數組中。
由于$ node數組中的元素是按照分類ID存放的,所以如果待處理的分類項還沒有被遍歷到,則說明該分類項是頂級分類,于是可以把該分類項直接加入$ tree數組中。函數最終返回$ tree數組,即無限極分類數組。
讀到這里,這篇“php無限極分類數組如何放”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。