《PHP實例:創(chuàng)建無限極分類樹型結(jié)構(gòu)的簡單方法》要點:
本文介紹了PHP實例:創(chuàng)建無限極分類樹型結(jié)構(gòu)的簡單方法,希望對您有用。如果有疑問,可以聯(lián)系我們。
PHP應用先上效果圖
PHP應用
PHP應用頂級分類其實就是一級分類,二級分類也叫作一級分類的子分類,在這個基礎(chǔ)上,子分類還可以擁有子分類,這樣就構(gòu)成了無限極分類.
PHP應用接下來看具體實現(xiàn)的代碼:
PHP應用一、在控制器中按字段查詢,查詢出所有分類信息(id:該分類的ID值,cate_name:該分類的名稱,pid:父ID,sorts:為顯示標題順序排序做準備,可不寫.)
PHP應用
public function cate_display()
{
$cate = D('Cate');
$field = array('id','cate_name','pid','sorts');
$list = $cate->allCategory($field);
$this->assign('list',$list);
$this->display();
}
PHP應用二、模型中的代碼
PHP應用在對應控制器的模型中創(chuàng)建兩個方法
PHP應用1.查詢所有分類信息,并調(diào)用生成分類樹方法:
PHP應用
public function allCategory($field='*'){
$data = $this->field($field)->select();
return $this->tree($data);
}
PHP應用2.生成分類樹(使用遞歸,傳進去數(shù)據(jù),以及pid[父類id],level[層數(shù),用來控制顯示的-數(shù)量]兩個變量,初始值為零)
PHP應用
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;
}
PHP應用三、視圖文件中的代碼
PHP應用
<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>
PHP應用這樣,一個可以無限遞歸的分類樹形結(jié)構(gòu)就完成了,總結(jié):核心思想還是模型中的遞歸函數(shù),先傳進去pid默認為零,以后每次遞歸傳入的pid就是上級的id,level用來記錄遞歸層數(shù),最后在視圖頁面顯示時,調(diào)用PHP內(nèi)置函數(shù)str_repeat(),用來重復輸出'-‘以達到輸出時區(qū)分級數(shù)的效果.
PHP應用以上這篇創(chuàng)建無限極分類樹型結(jié)構(gòu)的簡單方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持維易PHP.
轉(zhuǎn)載請注明本頁網(wǎng)址:
http://www.fzlkiss.com/jiaocheng/602.html