PHP利用遞歸函數(shù)實(shí)現(xiàn)無(wú)限級(jí)分類(lèi)的方法
相信很多學(xué)php的很多小伙伴都會(huì)嘗試做一個(gè)網(wǎng)上商城作為提升自己技術(shù)的一種途徑。各種對(duì)商品分類(lèi),商品名之類(lèi)的操作應(yīng)該是得心應(yīng)手,那么就可以嘗試下無(wú)限級(jí)分類(lèi)列表的制作了。
什么是無(wú)限級(jí)分類(lèi)?
無(wú)限級(jí)分類(lèi)是一種分類(lèi)技巧,例如部門(mén)組織,文章分類(lèi),學(xué)科分類(lèi)等常用到無(wú)限級(jí)分類(lèi),將其簡(jiǎn)單理解成分類(lèi)就好了。其實(shí)我們仔細(xì)想一下,生活中的分類(lèi)簡(jiǎn)直太多了,衣服可以分為男裝和女裝,也可以分為上衣和褲子,也可以根據(jù)年齡段分類(lèi)。分類(lèi)無(wú)處不在,分類(lèi)顯得“無(wú)限”。我這里就不說(shuō)無(wú)限分類(lèi)的必要性了。
無(wú)限級(jí)分類(lèi)原理簡(jiǎn)介
無(wú)限分類(lèi)看似"高大上",實(shí)際上原理是非常簡(jiǎn)單的 。無(wú)限分類(lèi)不僅僅需要代碼的巧妙性,也要依托數(shù)據(jù)庫(kù)設(shè)計(jì)的合理性。要滿(mǎn)足無(wú)限級(jí)分類(lèi),數(shù)據(jù)庫(kù)需要有兩個(gè)必須的字段,id,pid。id用來(lái)標(biāo)識(shí)自身,而pid則是用來(lái)表明父級(jí)id。也就是說(shuō),每個(gè)分類(lèi)記錄不僅描述了自身,還描述了與其關(guān)心最為緊密的另一個(gè)id。看似復(fù)雜的事情被這樣一個(gè)小技巧解決了。
php無(wú)限級(jí)分類(lèi)是經(jīng)常要用到的,本人以前一直用的是已經(jīng)寫(xiě)好的,所以沒(méi)仔細(xì)去研究過(guò),下面是一個(gè)使用遞歸實(shí)現(xiàn)的簡(jiǎn)單的php無(wú)限級(jí)分類(lèi)的函數(shù);也許這不是最優(yōu)的方法,但對(duì)于一般的應(yīng)用也足夠了。
數(shù)據(jù)表結(jié)構(gòu)
CREATE TABLE IF NOT EXISTS `category` ( `id` int(5) NOT NULL AUTO_INCREMENT COMMENT '唯一自增id', `pid` int(5) NOT NULL DEFAULT '0' COMMENT '父id', `sort` int(2) NOT NULL DEFAULT '0' COMMENT '排序數(shù)字', `name` varchar(30) DEFAULT NULL COMMENT '名稱(chēng)', PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='無(wú)限極分類(lèi)表' AUTO_INCREMENT=1 ;
數(shù)據(jù)
INSERT INTO `category` (`id`, `pid`, `sort`, `name`) VALUES (1, 0, 1, 'php'), (2, 0, 2, '數(shù)據(jù)庫(kù)'), (3, 0, 3, 'javascript'), (4, 1, 1, '框架模板'), (5, 1, 2, '函數(shù)總結(jié)'), (6, 2, 1, 'mysql'), (7, 4, 1, '框架'), (8, 4, 2, '模板'), (9, 8, 1, 'smarty'), (10, 7, 2, 'thinkphp'), (11, 10, 1, 'thinkphp技巧'), (12, 10, 2, 'thinkphp模板'), (13, 12, 3, '模板知識(shí)總結(jié)'), (14, 12, 2, '模板視頻教程'), (15, 11, 1, 'model技巧');
函數(shù)實(shí)現(xiàn)代碼
function tree(&$list,$pid=0,$level=0,$html='--'){
static $tree=array();
foreach($list as $v){
if($v['pid']==$pid){
$v['level']=$level;
$v['html']=str_repeat($html,$level);
$tree[]=$v;
tree($list,$v['id'],$level+1,$html);
}
}
return $tree;
}
以上tree函數(shù)的第一個(gè)參數(shù)$list就是獲取的如上表的一個(gè)二維數(shù)組的結(jié)果集。需要注意的是從數(shù)據(jù)庫(kù)獲取結(jié)果集的sql語(yǔ)句必須加上order by sort asc,否則sort字段將不能發(fā)揮排序的作用。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
- php求斐波那契數(shù)的兩種實(shí)現(xiàn)方式【遞歸與遞推】
- php菜單/評(píng)論數(shù)據(jù)遞歸分級(jí)算法的實(shí)現(xiàn)方法
- PHP實(shí)現(xiàn)無(wú)限極分類(lèi)的兩種方式示例【遞歸和引用方式】
- PHP自定義遞歸函數(shù)實(shí)現(xiàn)數(shù)組轉(zhuǎn)JSON功能【支持GBK編碼】
- PHP遞歸寫(xiě)入MySQL實(shí)現(xiàn)無(wú)限級(jí)分類(lèi)數(shù)據(jù)操作示例
- PHP數(shù)組遞歸排序?qū)崿F(xiàn)方法示例
- PHP迭代與遞歸實(shí)現(xiàn)無(wú)限級(jí)分類(lèi)
- PHP實(shí)現(xiàn)遞歸的三種方法
相關(guān)文章
PHP連接MySQL查詢(xún)結(jié)果中文顯示亂碼解決方法
MySQL和Apache兩個(gè)系統(tǒng)的編碼(字符集)問(wèn)題讓我費(fèi)勁腦筋,吃盡苦頭。網(wǎng)上對(duì)這些問(wèn)題的解決比較零散,比較片面,大部分是提供解決方法,卻不說(shuō)為什么。于是我將這幾天收獲總結(jié)一下,避免后來(lái)者再走彎路2013-10-10
Linux下實(shí)現(xiàn)PHP多進(jìn)程的方法分享
PHP多進(jìn)程:使用PHP的Process Control Functions(PCNTL/線(xiàn)程控制函數(shù)),需要的朋友可以參考下2012-08-08
PHP與MySQL開(kāi)發(fā)中頁(yè)面出現(xiàn)亂碼的一種解決方法
PHP與MySQL開(kāi)發(fā)中頁(yè)面出現(xiàn)亂碼的一種解決方法...2007-07-07
PHP中l(wèi)trim()函數(shù)的用法與實(shí)例講解
今天小編就為大家分享一篇關(guān)于PHP中l(wèi)trim()函數(shù)的用法與實(shí)例講解,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-03-03

