php創(chuàng)建無限級樹型菜單
寫遞歸函數(shù),可考慮緩存,定義一些靜態(tài)變量來存上一次運行的結(jié)果,多程序運行效率很有幫助.。
大概步驟如下:
step1:到數(shù)據(jù)庫取數(shù)據(jù),放到一個數(shù)組,
step2:把數(shù)據(jù)轉(zhuǎn)化為一個樹型狀的數(shù)組,
step3:把這個樹型狀的數(shù)組轉(zhuǎn)為html代碼。
也可以將第二步和第三步合為一步。
詳細(xì)如下:
1、數(shù)據(jù)庫設(shè)計:
CREATE TABLE `bg_cate` ( `cate_Id` int(30) unsigned NOT NULL AUTO_INCREMENT, `cate_ParentId` int(30) unsigned DEFAULT '0', `cate_Name` varchar(100) NOT NULL, `cate_Intro` varchar(500) DEFAULT NULL, `cate_Order` int(30) unsigned DEFAULT '0', `cate_Icon` varchar(100) DEFAULT NULL, PRIMARY KEY (`cate_Id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=34 ; -- -- 導(dǎo)出表中的數(shù)據(jù) `bg_cate` -- INSERT INTO `bg_cate` (`cate_Id`, `cate_ParentId`, `cate_Name`, `cate_Intro`, `cate_Order`, `cate_Icon`) VALUES (4, 0, '往事如風(fēng)', '記錄往事', 0, 'icons/6.gif'), (5, 0, '水煮三國', '品位三國智慧', 0, 'icons/3.gif'), (2, 0, '技術(shù)學(xué)習(xí)', '平時學(xué)習(xí)的一些筆記,歡迎批評指正。', 0, 'icons/18.gif'), (3, 0, '生活點滴', '記錄生活點滴', 0, 'icons/2.gif'), (6, 0, '梔子花開', '青春無限', 0, 'icons/8.gif'), (7, 0, '假日休閑', '悠閑、自在', 0, 'icons/24.gif'), (8, 2, 'html', 'html學(xué)習(xí)', 0, 'icons/1.gif'), (9, 2, 'css', 'css學(xué)習(xí)', 0, 'icons/1.gif'), (10, 2, 'php', 'php學(xué)習(xí)', 0, 'icons/18.gif'), (11, 10, 'php基礎(chǔ)知識', 'php基礎(chǔ)知識', 0, 'icons/1.gif'), (12, 10, 'oop', 'oop', 0, 'icons/1.gif'), (13, 10, 'php安全', '講述php安全', 0, 'icons/1.gif'), (14, 10, 'seagull framework', 'seagull framework', 0, 'icons/1.gif'), (15, 2, 'javascript', 'javascript學(xué)習(xí)', 0, 'icons/1.gif'), (16, 2, '設(shè)計模式', NULL, 0, 'icons/1.gif'), (17, 2, '軟件工程', '軟件工程學(xué)習(xí)', 0, 'icons/1.gif'), (18, 3, '廈門生活', '廈門生活', 0, 'icons/8.gif'), (19, 3, '大學(xué)生活', '大學(xué)生活', 0, 'icons/8.gif'), (20, 3, '童年生活', '童年生活', 0, 'icons/15.gif'), (21, 19, '學(xué)習(xí)', '學(xué)習(xí)', 0, 'icons/1.gif'), (22, 19, '運動', '運動', 0, 'icons/16.gif'), (23, 19, '旅游', '旅游', 0, 'icons/24.gif'), (24, 22, '排球', '排球', 0, 'icons/9.gif'), (25, 22, '籃球', '籃球', 0, 'icons/9.gif'), (26, 22, '羽毛球', '羽毛球', 0, 'icons/9.gif'), (27, 22, '乒乓球', '乒乓球', 0, 'icons/9.gif');
2、到數(shù)據(jù)庫取數(shù)據(jù),放到數(shù)組:
require_once './classes/MyDB.php'; $con = MyDB::singleton(); $sql = <<<SQL select * from bg_cate cate SQL; $data = $con->getAll($sql); //print_r($data);
數(shù)據(jù)庫操作我用的是pear類庫,最后的$data的數(shù)據(jù)格式如下:
Array ( [0] => Array ( [cate_Id] => 4 [cate_ParentId] => 0 [cate_Name] => 往事如風(fēng) [cate_Intro] => 記錄往事 [cate_Order] => 0 [cate_Icon] => icons/6.gif ) [1] => Array ( [cate_Id] => 5 [cate_ParentId] => 0 [cate_Name] => 水煮三國 [cate_Intro] => 品位三國智慧 [cate_Order] => 0 [cate_Icon] => icons/3.gif )
3、把上一步的數(shù)據(jù)轉(zhuǎn)為樹型狀的數(shù)組代碼如下:
function getTree($data, $pId)
{
$tree = '';
foreach($data as $k => $v)
{
if($v['cate_ParentId'] == $pId)
{ //父親找到兒子
$v['cate_ParentId'] = getTree($data, $v['cate_Id']);
$tree[] = $v;
//unset($data[$k]);
}
}
return $tree;
}
$tree = getTree($data, 0);
最后輸出$tree的數(shù)據(jù)格式為:
Array ( [0] => Array ( [cate_Id] => 4 [cate_ParentId] => [cate_Name] => 往事如風(fēng) [cate_Intro] => 記錄往事 [cate_Order] => 0 [cate_Icon] => icons/6.gif ) [1] => Array ( [cate_Id] => 5 [cate_ParentId] => [cate_Name] => 水煮三國 [cate_Intro] => 品位三國智慧 [cate_Order] => 0 [cate_Icon] => icons/3.gif ) [2] => Array ( [cate_Id] => 2 [cate_ParentId] => Array ( [0] => Array ( [cate_Id] => 8 [cate_ParentId] => [cate_Name] => html [cate_Intro] => html學(xué)習(xí) [cate_Order] => 0 [cate_Icon] => icons/1.gif )
4、把樹型狀數(shù)組轉(zhuǎn)為html代碼如下:
function procHtml($tree)
{
$html = '';
foreach($tree as $t)
{
if($t['cate_ParentId'] == '')
{
$html .= "<li>{$t['cate_Name']}</li>";
}
else
{
$html .= "<li>".$t['cate_Name'];
$html .= procHtml($t['cate_ParentId']);
$html = $html."</li>";
}
}
return $html ? '<ul>'.$html.'</ul>' : $html ;
}
echo procHtml($tree);
輸出的html的代碼格式為:
<ul>
<li>往事如風(fēng)</li>
<li>水煮三國</li>
<li>技術(shù)學(xué)習(xí)
<ul>
<li>html</li>
<li>css</li>
<li>php
<ul>
<li>php基礎(chǔ)知識</li>
<li>oop</li>
<li>php安全</li>
5、也可以把第3和第4步的代碼合在一起,代碼如下:
function getTree($data, $pId)
{
$html = '';
foreach($data as $k => $v)
{
if($v['cate_ParentId'] == $pId)
{ //父親找到兒子
$html .= "<li>".$v['cate_Name'];
$html .= getTree($data, $v['cate_Id']);
$html = $html."</li>";
}
}
return $html ? '<ul>'.$html.'</ul>' : $html ;
}
echo getTree($data, 0);
6、最后再加點css樣式,效果如下:

整個過程思路很清晰,非常適合第一次創(chuàng)建無限級樹型的朋友學(xué)習(xí),希望大家都有所收獲。
- php 三級聯(lián)動菜單
- jQuery+PHP+MySQL二級聯(lián)動下拉菜單實例講解
- ThinkPHP使用心得分享-ThinkPHP + Ajax 實現(xiàn)2級聯(lián)動下拉菜單
- 落伍首發(fā) php+mysql 采用ajax技術(shù)的 省 市 地 3級聯(lián)動無刷新菜單 源碼
- 基于遞歸實現(xiàn)的php樹形菜單代碼
- PHP導(dǎo)航下拉菜單的實現(xiàn)如此簡單
- PHP無限分類代碼,支持?jǐn)?shù)組格式化、直接輸出菜單兩種方式
- PHP 向右側(cè)拉菜單實現(xiàn)代碼,測試使用中
- php側(cè)拉菜單 漂亮,可以向右或者向左展開,支持FF,IE
- 用PHP實現(xiàn)多級樹型菜單
- PHP+JS三級菜單聯(lián)動菜單實現(xiàn)方法
相關(guān)文章
PHP實現(xiàn)的簡單操作SQLite數(shù)據(jù)庫類與用法示例
這篇文章主要介紹了PHP實現(xiàn)的簡單操作SQLite數(shù)據(jù)庫類與用法,結(jié)合具體實例形式分析了php封裝的針對SQLite數(shù)據(jù)庫相關(guān)增刪改查操作技巧與使用方法,需要的朋友可以參考下2017-06-06
PHP中round()函數(shù)對浮點數(shù)進(jìn)行四舍五入的方法
這篇文章主要介紹了PHP中round()函數(shù)對浮點數(shù)進(jìn)行四舍五入的方法,通過詳盡的實例對round()函數(shù)的各種常見用法進(jìn)行了歸納整理,是非常實用的技巧,需要的朋友可以參考下2014-11-11
深入理解PHP原理之Session Gc的一個小概率Notice
PHP Notice: session_start(): ps_files_cleanup_dir2011-04-04
php array_slice 取出數(shù)組中的一段序列實例
這篇文章主要介紹了php array_slice 取出數(shù)組中的一段序列實例的相關(guān)資料,這里提供了代碼,需要的朋友可以參考下2016-11-11
php+html5基于websocket實現(xiàn)聊天室的方法
這篇文章主要介紹了php+html5基于websocket實現(xiàn)聊天室的方法,實例分析了php結(jié)合html5的websocket通訊的使用技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-07-07
php 函數(shù)中靜態(tài)變量使用的問題實例分析
這篇文章主要介紹了php 函數(shù)中靜態(tài)變量使用的問題,結(jié)合實例形式分析了php 函數(shù)中靜態(tài)變量使用過程中遇到的問題,以及相關(guān)操作注意事項,需要的朋友可以參考下2020-03-03
php解析xml提示Invalid byte 1 of 1-byte UTF-8 sequence錯誤的處理方法
在利用php解析xml時提示Invalid byte 1 of 1-byte UTF-8 sequence錯誤了,這個問題我百度查實說是編碼問題,結(jié)果我把編碼處理一下果然KO了,下面我來分享一下解決辦法2013-11-11

