//所用數據表的結構
CREATE TABLE `cr_columninfo` (
`columnid` int(4) NOT NULL auto_increment,
`columnfatherid` int(4) NOT NULL default '0',
`columnname` varchar(100) NOT NULL default '',
`columnadder` varchar(50) NOT NULL default '',
`columninputdate` date NOT NULL default '0000-00-00',
PRIMARY KEY (`columnid`)
) ENGINE=MyISAM AUTO_INCREMENT=15 DEFAULT CHARSET=utf8 AUTO_INCREMENT=15 ;
//PHP源程序如下:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>類別目錄樹</title>
<script type="text/javascript">
function ShowMenu(MenuID)
{
if(MenuID.style.display=="none"){
MenuID.style.display="";
}
else{
MenuID.style.display="none
}
}
</script>
<link href="style.css" rel="stylesheet" type="text/css">
</head>
<body topmargin="0" bgcolor="#EFEFE7">
<table width="100%" height="25" border="0" cellpadding="0" cellspacing="0" bgcolor="#739E18">
<tr>
<td align="left"><strong>類別目錄樹</strong></td>
</tr>
</table>
<?
//基本變量設置
$GLOBALS["ID"] =1; //用來跟蹤下拉菜單的ID號
$layer=1; //用來跟蹤當前菜單的級數
//連接數據庫
$datebase["host"]="localhost:6033"; //主機
$datebase["user"] = "ms"; //用戶名
$datebase["password"]= "ms";//密碼
$datebase["db"]="edu"; //數據庫
$Con=mysql_connect($datebase["host"], $datebase["user"], $datebase["password"]) or die("連接數據庫出錯: " . mysql_error());
mysql_select_db($datebase["db"],$Con) or die("Select Datebase Error: " . mysql_error());
//提取一級菜單
$sql="select * from menu where columnfatherid=0";
$result=mysql_query($sql,$Con);
//如果一級菜單存在則開始菜單的顯示
if(mysql_num_rows($result)>0) ShowTreeMenu($Con,$result,$ID);
//=============================================
//顯示樹型菜單函數 ShowTreeMenu($con,$result,$layer)
//$con:數據庫連接
//$result:需要顯示的菜單記錄集
//$layer:需要顯示的菜單的級數
//=============================================
function ShowTreeMenu($Con,$result,$layer)
{
//取得需要顯示的菜單的項目數
$numrows=mysql_num_rows($result);
//開始顯示菜單,每個子菜單都用一個表格來表示
echo "<table cellpadding='0' cellspacing='0' border='0' width='100%'>";
for($rows=0;$rows<$numrows;$rows++)
{
//將當前菜單項目的內容導入數組
$menu=mysql_fetch_array($result);
//提取菜單項目的子菜單記錄集
$sql="select * from menu where columnfatherid=".$menu[columnid];
$result_sub=mysql_query($sql,$Con);
echo "<tr>";
//如果該菜單項目有子菜單,則添加Javascrīpt onClick語句
if(mysql_num_rows($result_sub)>0)
{
echo "<td width='20'><span onclick='ShowMenu(Menu".$GLOBALS['ID'].")' ><img src='img/plus.gif' border='0' ></span> </td>";
echo "<td class='Menu' >";
}
else{
echo "<td width='20'><img src='img/page.gif' border='0'></td>";
echo "<td class='Menu'>";
}
//如果該菜單項目沒有子菜單,只顯示菜單名稱
echo $menu[columnname];
echo "</td></tr>";
//如果該菜單項目有子菜單,則顯示子菜單
if(mysql_num_rows($result_sub)>0)
{
//指定該子菜單的ID和style,以便和onClick語句相對應
echo "<tr id=Menu".$GLOBALS["ID"]++." style='display:none'>"; //
echo "<td width='20'> </td>";
echo "<td>";
//將級數加1
$layer++;
//遞歸調用ShowTreeMenu()函數,生成子菜單
ShowTreeMenu($Con,$result_sub,$layer);
//子菜單處理完成,返回到遞歸的上一層
echo "</td></tr>";
}
//子菜單處理完成,返回到遞歸的上一層,將級數減1
$layer--;
}
echo "</table>";
}
?>
</body>
</html>