本文主要為大家帶來一篇創建無限極分類樹型結構的簡單方法。小編覺得蠻不錯的,現在就分享給大家,也給大家做個參考。一起跟著小編過來看看吧,希望能幫助大家。
先上效果圖
頂級分類其實就是一級分類,二級分類也叫作一級分類的子分類,在這個基礎上,子分類還可以擁有子分類,這樣就構成了無限極分類。
接下來看具體實現的程式碼:
一、在控制器中按字段查詢,查詢出所有分類資訊(id:該分類的ID值,cate_name:該分類的名稱,pid:父ID,sorts:為顯示標題順序排序做準備,可不寫。
1.查詢所有分類信息,並呼叫生成分類樹方法:
public function cate_display() { $cate = D('Cate'); $field = array('id','cate_name','pid','sorts'); $list = $cate->allCategory($field); $this->assign('list',$list); $this->display(); }
2.產生分類樹(使用遞歸,傳進去數據,以及pid[父類id],level[層數,用來控制顯示的-數量]兩個變量,初始值為零)
public function allCategory($field='*'){ $data = $this->field($field)->select(); return $this->tree($data); }
三、視圖文件中的代碼
public function tree($data,$pid=0,$level=0){ static $tree = array(); foreach($data as $k=>$v){ if($v['pid'] == $pid){ $v['level'] = $level; $tree[]=$v; $this->tree($data,$v['id'],$level+1); } } return $tree; }
這樣,一個可以無限遞歸的分類樹形結構就完成了,總結:核心思想還是模型中的遞歸函數,先傳入去pid預設為零,以後每次遞歸傳入的pid就是上級的id,level用來記錄遞歸層數,最後在視圖頁面顯示時,呼叫PHP內建函數str_repeat(),用來重複輸出'-'以達到輸出時區分級數的效果。
相關推薦:
php無需遞歸實現無限極分類樹
以上是如何創建無限極分類樹型結構的詳細內容。更多資訊請關注PHP中文網其他相關文章!