php無限極分類
php無限極分類是經常要用到的,本人以前一直用的是已經寫好的,所以沒仔細去研究過,今天由於項目的需要,需要臨時做一個php無限極分類的東東,遂做了一個最簡單的,現記錄如下,有需要的朋友可以看下。
資料表結構
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 '排序數字', `name` varchar(30) DEFAULT NULL COMMENT '名稱', PRIMARY KEY (`id`)) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='無限極分類表' AUTO_INCREMENT=1 ;
資料
INSERT INTO `category` (`id`, `pid`, `sort`, `name`) VALUES(1, 0, 1, 'php'),(2, 0, 2, '資料庫'),(3, 0, 3, 'javascript'),(4, 1, 1, '架構模板'),(5, 1, 2, '函數總結'),(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, '模板知識總結'),(14, 12, 2, '模板視頻教程'),(15, 11, 1, 'model技巧');
函數實現代碼
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函數的第一個參數$list就是擷取的如上表的一個二維數組的結果集。需要注意的是從資料庫擷取結果集的sql語句必須加上order by sort asc,否則sort欄位將不能發揮排序的作用。
您可能感興趣的文章
- php清空(刪除)指定目錄下的檔案,不刪除目錄檔案夾的方法
- php擷取某段時間內每個月的方法,返回由這些月份組成的數組
- php 擷取今日、昨日、上周、本月的起始時間戳記和結束時間戳記的方法
- PHP setcookie無效的原因分析
- php 擷取今天明天昨天時間戳記的 N 種方法總結
- PHP壓縮html網頁代碼(清除空格,分行符號,定位字元,注釋標記)
- PHP新手用的Insert和Update語句構造類
- PHP中如何將陣列變數寫入到檔案
http://www.bkjia.com/PHPjc/1058849.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/1058849.htmlTechArticlephp無限極分類 php無限極分類是經常要用到的,本人以前一直用的是已經寫好的,所以沒仔細去研究過,今天由於項目的需要,需要臨時做一...