創(chuàng)建無限極分類樹型結(jié)構(gòu)的簡單方法
先上效果圖
頂級分類其實就是一級分類,二級分類也叫作一級分類的子分類,在這個基礎(chǔ)上,子分類還可以擁有子分類,這樣就構(gòu)成了無限極分類。
接下來看具體實現(xiàn)的代碼:
一、在控制器中按字段查詢,查詢出所有分類信息(id:該分類的ID值,cate_name:該分類的名稱,pid:父ID,sorts:為顯示標(biāo)題順序排序做準(zhǔn)備,可不寫。)
public function cate_display() { $cate = D('Cate'); $field = array('id','cate_name','pid','sorts'); $list = $cate->allCategory($field); $this->assign('list',$list); $this->display(); }
二、模型中的代碼
在對應(yīng)控制器的模型中創(chuàng)建兩個方法
1.查詢所有分類信息,并調(diào)用生成分類樹方法:
public function allCategory($field='*'){ $data = $this->field($field)->select(); return $this->tree($data); }
2.生成分類樹(使用遞歸,傳進(jìn)去數(shù)據(jù),以及pid[父類id],level[層數(shù),用來控制顯示的-數(shù)量]兩個變量,初始值為零)
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; }
三、視圖文件中的代碼
<div class="form-group"> <label for="pid" class="col-sm-2 control-label no-padding-right">上級菜單</label> <div class="col-sm-6"> <select name="pid" style="width: 100%;"> <option selected="selected" value="0">頂級菜單</option> <volist name="row" id="val"> <option value="{$val.id}"><?php echo str_repeat('-',$val['level']*4); ?>{$val.cate_name} </option> </volist> </select> </div> </div>
這樣,一個可以無限遞歸的分類樹形結(jié)構(gòu)就完成了,總結(jié):核心思想還是模型中的遞歸函數(shù),先傳進(jìn)去pid默認(rèn)為零,以后每次遞歸傳入的pid就是上級的id,level用來記錄遞歸層數(shù),最后在視圖頁面顯示時,調(diào)用PHP內(nèi)置函數(shù)str_repeat(),用來重復(fù)輸出'-‘以達(dá)到輸出時區(qū)分級數(shù)的效果。
以上這篇創(chuàng)建無限極分類樹型結(jié)構(gòu)的簡單方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
ThinkPHP讓../Public在模板不解析(直接輸出)的方法
這篇文章主要介紹了ThinkPHP讓../Public在模板不解析,直接輸出的方法,涉及通過模板常量設(shè)置修改默認(rèn)變量替換的技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-10-10php小型企業(yè)庫存管理系統(tǒng)的設(shè)計與實現(xiàn)代碼
雙專業(yè)畢業(yè)論文做了一個小型企業(yè)庫存管理系統(tǒng),使用PHP&mysql組合進(jìn)行開發(fā)。頭一次開發(fā)稍微大一點的東西,php也是自學(xué)的2011-05-05Laravel框架實現(xiàn)的使用smtp發(fā)送郵件功能示例
這篇文章主要介紹了Laravel框架實現(xiàn)的使用smtp發(fā)送郵件功能,結(jié)合實例形式分析了Laravel框架相關(guān)配置及郵件發(fā)送操作技巧,需要的朋友可以參考下2019-03-03Mac版PhpStorm之XAMPP整合apache服務(wù)器配置的圖文教程詳解
選擇在PhpStorm集成apache服務(wù)器,但是很多朋友不知道是如何操作的,下面小編分步驟通過圖文的形式給大家介紹Mac版PhpStorm之XAMPP整合apache服務(wù)器配置的教程,感興趣的朋友一起看看吧2016-10-10