色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

PHP+JS無(wú)限級(jí)可伸縮菜單詳解(簡(jiǎn)單易懂)

發(fā)了幾天基礎(chǔ)的東西,今天來(lái)點(diǎn)稍微難的,一般在CMS系統(tǒng)后臺(tái)中都要用到的類別管理部分的精華--無(wú)限級(jí)分類菜單,對(duì)于新手來(lái)說(shuō),這個(gè)可能有一定難度,但是今天聽完我細(xì)細(xì)道來(lái),相信以后大家就都會(huì)弄這東東了。怎么實(shí)現(xiàn)呢?大家先做個(gè)數(shù)據(jù)庫(kù)出來(lái)先:
-- 
-- 表的結(jié)構(gòu) `cr_columninfo`
-- 
復(fù)制代碼 代碼如下: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 ; 
-- 導(dǎo)出表中的數(shù)據(jù) `cr_columninfo`
-- 
INSERT INTO `cr_columninfo` (`columnid`, `columnfatherid`, `columnname`, `columnadder`, `columninputdate`) VALUES (1, 0, '影音明星', 'leehui', '2006-09-28'),
(2, 0, '校園風(fēng)情', 'leehui1983', '2006-09-28'),
(3, 1, '港臺(tái)明星', 'leehui', '2006-09-28'),
(4, 0, '風(fēng)景圖片', 'leehui1983', '2006-09-29'),
(5, 4, '浩瀚大海', 'leehui1983', '2006-09-29'),
(6, 5, '福州的海', 'leehui1983', '2006-09-29'),
(7, 2, '畢業(yè)圖片', 'leehui', '2006-09-29'),
(9, 0, '體育明星', 'leehui1983', '2006-10-02'),
(10, 0, '精美壁紙', 'leehui1983', '2006-10-02'),
(11, 0, '城市風(fēng)光', 'leehui1983', '2006-10-02'),
(12, 0, '卡通動(dòng)漫', 'leehui1983', '2006-10-02'),
(13, 0, '游戲截圖', 'leehui1983', '2006-10-02'),
(14, 0, '作者相冊(cè)', 'leehui1983', '2006-10-02');
這些是測(cè)試數(shù)據(jù),基本原理就是按照樹型結(jié)構(gòu)建立數(shù)據(jù)字段,核心就是欄目都有本身的ID號(hào)和父欄目的ID號(hào),依靠這兩個(gè)關(guān)系,建立樹型結(jié)構(gòu),頂級(jí)欄目父ID=0,這個(gè)都好理解,現(xiàn)在來(lái)敘述下程序執(zhí)行原理,本程序采用最為普遍的遞歸算法來(lái)遍歷子菜單,首先,先查詢出所有頂級(jí)菜單,顯示在一個(gè)大表格里,沒一行顯示一個(gè)頂級(jí)菜單,再通過遞歸列出所有子菜單,子菜單處在上級(jí)菜單的所在行的下一行,且行的顯示屬性為不顯示,通過程序動(dòng)態(tài)生成的行ID號(hào),結(jié)合JS控制行的顯示與隱藏,也就是類似于微軟菜單的可伸縮效果,文章最后有張圖有助于大家理解,這是把生成頁(yè)面的HTML復(fù)制進(jìn)DW來(lái)只管演示程序的最終結(jié)果。
來(lái)看代碼部分,并沒有難懂的語(yǔ)法,請(qǐng)大家借助注釋自己閱讀,有興趣可擴(kuò)展此代碼。
php代碼如下: 
復(fù)制代碼 代碼如下:<html> 
<head> 
<meta http-equiv="Content-Type" c /> 
<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>欄目樹形結(jié)構(gòu)列表</strong></td> 
  </tr> 
</table> 
<?php 
     //基本變量設(shè)置  
     $GLOBALS["ID"] =1; //用來(lái)跟蹤下拉菜單的ID號(hào)  
     $layer=1; //用來(lái)跟蹤當(dāng)前菜單的級(jí)數(shù)  
     //連接數(shù)據(jù)庫(kù)  
     $Con=mysql_connect("localhost","root","7529639");  
     mysql_select_db("cr_download");  
     mysql_query("SET NAMES 'GBK'"); 
     //提取一級(jí)菜單  
     $sql="select * from cr_columninfo where columnfatherid=0";  
     $result=mysql_query($sql,$Con);  
     //如果一級(jí)菜單存在則開始菜單的顯示  
     if(mysql_num_rows($result)>0) ShowTreeMenu($Con,$result,$ID);  
     //=============================================  
     //顯示樹型菜單函數(shù) ShowTreeMenu($con,$result,$layer)  
     //$con:數(shù)據(jù)庫(kù)連接  
     //$result:需要顯示的菜單記錄集  
     //$layer:需要顯示的菜單的級(jí)數(shù)  
     //=============================================  
     function ShowTreeMenu($Con,$result,$layer)  
     {  
       //取得需要顯示的菜單的項(xiàng)目數(shù)  
       $numrows=mysql_num_rows($result);  
       //開始顯示菜單,每個(gè)子菜單都用一個(gè)表格來(lái)表示  
       echo "<table cellpadding='0' cellspacing='0' border='0' width='100%'>";  
      for($rows=0;$rows<$numrows;$rows++)  
      {  
        //將當(dāng)前菜單項(xiàng)目的內(nèi)容導(dǎo)入數(shù)組  
        $menu=mysql_fetch_array($result);  
        //提取菜單項(xiàng)目的子菜單記錄集  
        $sql="select * from cr_columninfo where columnfatherid=$menu[columnid]";  
        $result_sub=mysql_query($sql,$Con);  
        echo "<tr>";  
        //如果該菜單項(xiàng)目有子菜單,則添加JavaScript onClick語(yǔ)句  
        if(mysql_num_rows($result_sub)>0)  
        {  
          echo "<td width='20'><img src='./images/plus.png' border='0' > </td>";  
          echo "<td class='Menu' >";  
        }  
        else{  
          echo "<td width='20'><img src='./images/page.png' border='0'> </td>";  
          echo "<td class='Menu'>";  
        }  
     //如果該菜單項(xiàng)目沒有子菜單,只顯示菜單名稱  
     echo $menu[columnname]; 
     echo "</td></tr>";  
     //如果該菜單項(xiàng)目有子菜單,則顯示子菜單  
     if(mysql_num_rows($result_sub)>0)  
     {  
      //指定該子菜單的ID和style,以便和onClick語(yǔ)句相對(duì)應(yīng)  
      echo "<tr id=Menu".$GLOBALS["ID"]++." style='display:none'>";  
      echo "<td width='20'> </td>";  
      echo "<td>";  
     //將級(jí)數(shù)加1  
     $layer++;  
     //遞歸調(diào)用ShowTreeMenu()函數(shù),生成子菜單  
     ShowTreeMenu($Con,$result_sub,$layer);  
     //子菜單處理完成,返回到遞歸的上一層 
     echo "</td></tr>";  
     }  
     //子菜單處理完成,返回到遞歸的上一層,將級(jí)數(shù)減1  
     $layer--;  
   }  
     echo "</table>";  
  }  
?> 
</body> 
</html>
最后貼上效果圖和源代碼打包,希望本文對(duì)大家有所幫助^_^
下載文件 下載此文件 

php技術(shù)PHP+JS無(wú)限級(jí)可伸縮菜單詳解(簡(jiǎn)單易懂),轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 许昌市| 辉南县| 扎兰屯市| 乌恰县| 额济纳旗| 丰镇市| 祁门县| 睢宁县| 汝南县| 南陵县| 界首市| 文水县| 樟树市| 余江县| 中方县| 宜阳县| 汝州市| 盐源县| 项城市| 岱山县| 新平| 德令哈市| 铁力市| 江川县| 舒城县| 宁津县| 仁寿县| 玛沁县| 阿克苏市| 庆城县| 海淀区| 疏附县| 报价| 平罗县| 措勤县| 五莲县| 衢州市| 罗平县| 兰坪| 潼南县| 万全县|