什么是無限分類?
無限分類就是一個(gè)分類下面可以創(chuàng)建多個(gè)子類愕鼓,而其子類下面亦可以創(chuàng)建不同子類钙态,如此往復(fù),沒有終點(diǎn)菇晃;
分類在生活中的體現(xiàn)
實(shí)現(xiàn)方法
以父ID實(shí)現(xiàn)的無限分類
使用遞歸算法册倒,表中一個(gè)字段id,一個(gè)字段pid(父id)磺送;這樣可以根據(jù)WHERE id=pid來查出上一級(jí)的內(nèi)容驻子,然后一層一層的查出最上面的內(nèi)容灿意,運(yùn)用遞歸至頂層。
遞歸就是一種程序自身調(diào)用自身的一種編程技巧
遞歸的簡單實(shí)例:
function digui($i=1) {
echo $i;
$i++;
if ($i<10) {
$this->digui($i);
}
}
用for循環(huán)也可以實(shí)現(xiàn)崇呵,所以說明遞歸就是一個(gè)循環(huán)缤剧;
遞歸無限分類原理
每一個(gè)分類都需要記錄它的父級(jí)id,當(dāng)為頂級(jí)分類時(shí)域慷,父級(jí)id為0荒辕;這樣無論哪個(gè)分類,都可以通過父級(jí)id一層層的去查明它所有的父級(jí)犹褒,以便清楚知道它所屬何種分類抵窒,層級(jí)深度為幾。
由這張圖可以看出這個(gè)分類的層級(jí)深度是4化漆;
數(shù)據(jù)表設(shè)計(jì)
表中需要說明一下cateorder排序字段:當(dāng)層級(jí)深度是一樣的時(shí)候我們讓哪個(gè)數(shù)據(jù)在前哪個(gè)數(shù)據(jù)在后估脆,這個(gè)時(shí)候就可以利用這個(gè)字段钦奋,設(shè)置一個(gè)數(shù)字座云,小的排在前面,大的排在后面付材;
應(yīng)用場(chǎng)景
一般在我們后臺(tái)功能模塊里面的分類需要運(yùn)用
無限分類代碼實(shí)現(xiàn)
第一種:遞歸
function digui($pid=0,$arr=array(),$level=''){
$where['pid'] = $pid;
$model = M('cate');
$data = $model->where($where)->select();
$level++;
if ($data) {
foreach ($data as $v) {
$v['level'] = $level;
$v['name'] = '|'.str_repeat('--',$level).$v['name'];
$arr[] = $v;
$arr = $this->digui($v['id'],$arr,$level);
}
}
return $arr;
}
視圖層代碼
<select>
<option value="0">頂級(jí)分類</option>
<volist name="data" id="v">
<option value="{$v.id}">{$v.name}</option>
</volist>
</select>
第二種:將分類表重構(gòu)數(shù)組以無限極目錄樹的形式展現(xiàn)
$category = M('cate')->select();
//以主鍵ID為下標(biāo)重構(gòu)數(shù)組
foreach ($category as $k=>$v) {
$arr[$v['id']] = $v;
}
//無限極分類數(shù)據(jù)樹形結(jié)構(gòu)化
$tree = array();
foreach($arr as $arrs){
if(isset($arr[$arrs['pid']])){
$arr[$arrs['pid']]['menu'][] = &$arr[$arrs['id']];
}else{
$tree[] = &$arr[$arrs['id']];
}
}
前臺(tái)模板循環(huán)調(diào)出分類菜單
<select style="width: 200px;">
<volist name="category" id="v">
<option value="{$v.pid}">一級(jí)菜單|-{$v.name}</option>
<volist name="v['menu']" id="va">
<option value="{$va.pid}">二級(jí)菜單|--{$va.name}</option>
<volist name="va['menu']" id="val">
<option value="{$val.pid}">三級(jí)菜單|---{$val.name}</option>
</volist>
</volist>
</volist>
</select>