php無限極分類_PHP教程

來源:互聯網
上載者:User

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無限極分類是經常要用到的,本人以前一直用的是已經寫好的,所以沒仔細去研究過,今天由於項目的需要,需要臨時做一...

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.