欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

PHP+JS无限级可伸缩菜单详解(简单易懂)

程序员文章站 2022-06-01 09:33:47
发了几天基础的东西,今天来点稍微难的,一般在cms系统后台中都要用到的类别管理部分的精华--无限级分类菜单,对于新手来说,这个可能有一定难度,但是今天听完我细细道来,相信以...
发了几天基础的东西,今天来点稍微难的,一般在cms系统后台中都要用到的类别管理部分的精华--无限级分类菜单,对于新手来说,这个可能有一定难度,但是今天听完我细细道来,相信以后大家就都会弄这东东了。怎么实现呢?大家先做个数据库出来先:
-- 
-- 表的结构 `cr_columninfo`
-- 
复制代码 代码如下:
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 ; 
-- 导出表中的数据 `cr_columninfo`
-- 
insert into `cr_columninfo` (`columnid`, `columnfatherid`, `columnname`, `columnadder`, `columninputdate`) values (1, 0, '影音明星', 'leehui', '2006-09-28'),
(2, 0, '校园风情', 'leehui1983', '2006-09-28'),
(3, 1, '港台明星', 'leehui', '2006-09-28'),
(4, 0, '风景图片', 'leehui1983', '2006-09-29'),
(5, 4, '浩瀚大海', 'leehui1983', '2006-09-29'),
(6, 5, '福州的海', 'leehui1983', '2006-09-29'),
(7, 2, '毕业图片', 'leehui', '2006-09-29'),
(9, 0, '体育明星', 'leehui1983', '2006-10-02'),
(10, 0, '精美壁纸', 'leehui1983', '2006-10-02'),
(11, 0, '城市风光', 'leehui1983', '2006-10-02'),
(12, 0, '卡通动漫', 'leehui1983', '2006-10-02'),
(13, 0, '游戏截图', 'leehui1983', '2006-10-02'),
(14, 0, '作者相册', 'leehui1983', '2006-10-02');

这些是测试数据,基本原理就是按照树型结构建立数据字段,核心就是栏目都有本身的id号和父栏目的id号,依靠这两个关系,建立树型结构,*栏目父id=0,这个都好理解,现在来叙述下程序执行原理,本程序采用最为普遍的递归算法来遍历子菜单,首先,先查询出所有*菜单,显示在一个大表格里,没一行显示一个*菜单,再通过递归列出所有子菜单,子菜单处在上级菜单的所在行的下一行,且行的显示属性为不显示,通过程序动态生成的行id号,结合js控制行的显示与隐藏,也就是类似于微软菜单的可伸缩效果,文章最后有张图有助于大家理解,这是把生成页面的html复制进dw来只管演示程序的最终结果。
来看代码部分,并没有难懂的语法,请大家借助注释自己阅读,有兴趣可扩展此代码。
php代码如下: 
复制代码 代码如下:
<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>栏目树形结构列表</strong></td> 
  </tr> 
</table> 
<?php 
     //基本变量设置  
     $globals["id"] =1; //用来跟踪下拉菜单的id号  
     $layer=1; //用来跟踪当前菜单的级数  
     //连接数据库  
     $con=mysql_connect("localhost","root","7529639");  
     mysql_select_db("cr_download");  
     mysql_query("set names 'gbk'"); 
     //提取一级菜单  
     $sql="select * from cr_columninfo 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 cr_columninfo where columnfatherid=$menu[columnid]";  
        $result_sub=mysql_query($sql,$con);  
        echo "<tr>";  
        //如果该菜单项目有子菜单,则添加javascript onclick语句  
        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'>";  
        }  
     //如果该菜单项目没有子菜单,只显示菜单名称  
     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>

最后贴上效果图和源代码打包,希望本文对大家有所帮助^_^
PHP+JS无限级可伸缩菜单详解(简单易懂)