无限级别菜单的实现


Posted in PHP onOctober 09, 2006

<?  /* 看到很多朋友问过无限级别菜单的的问题(其实理论上还是有级别的,毕竟要受到个方便的条件的限制,比如: 数据库字段的类型等),我曾经用老大(唠叨)提供的代码写出来过无限级别的菜单,但是感觉效果不是很好(视觉上),于是趁着"夜深人静"就写这个"无限制级别的菜单",其实道理很简单,主要是数据表的设计,还有递归方法的使用(如果有时间我会用中值排序法来做),我会在下面给出数据结构的设计(非常简单),这里我没有加上竖直的虚线(windows资源管理器的虚线),同时Sql语句我也将其固定,大家可以根据自己的需要来修改!如果有问题可以联系我:msn:banneryue@sina.com,QQ:7665656,E_mail:yuepengfei@mail.banner.com.cn

明天(已经是今天了,呵呵)我会提供一个测试页面让大家来看(因为我在宿舍只能拨号上网,Ip地址不固定)

*/

/** 递归显示子节点函数
*
*
* @param $SearchPattern    查找的条件(like)
* @param $BaseNum 节点的层数
*/

           function ListChildTree($SearchPattern,$BaseNum){
               global $Tree;//声明连接数据库的句柄为全局
               $Sql="select DepartmentId,DepartmentName from test where DepartmentId like '$SearchPattern'";    //查找孩子节点
               $QueryChild=$Tree->query($Sql);          
               while($Result=$Tree->fetch_array($QueryChild)) { //取出孩子节点
                   $Space="";
                    for($j=0;$j<((strlen($SearchPattern)/3)-$BaseNum);$j++)
                      $Space.="  ";                 //设置显示节点前面的距离,这里的空格的html被这里自动替换成"  "了
                   $ChildDepartment=trim($Result[0])."___";            
                   $ChildSql="select count(*) from test where DepartmentId like '$ChildDepartment'";//查找孩子节点的孩子节点
                   $ChildResult=$Tree->query_first($ChildSql);             
                   $TableId="ta".trim($Result[0]); //设置表格Id
                   $TablePic="ta".trim($Result[0])."pic";    //设置图片Id                   
                   if($ChildResult[0]<1){//如果没有找到孩子节点的节点,则显示"-"图片
                      ?>
                    <tr><td><?=$Space?><span align="absmiddle"><img src="leaf.gif" border="0" align="absmiddle" width="35" height="17"></span><font size="2"><A href="process.php?SearchPattern=<?=trim($Result[0])?>" class="F1"><?=$Result[1]?></a></font>
                    <table id="<?=$TableId?>" style="display=none" cellspacing="0" cellpadding="0">

                 <?}else{           //找到则显示"+"图片            
                  ?>
                   <tr><td><?=$Space?><a onclick="javascript:expands('<?=$TableId?>','<?=$TablePic?>')" style="cursor:hand"><span align="absmiddle"><img id="<?=$TablePic?>" src="parent.gif" border="0" align="absmiddle" width="35" height="17"></span></a><font size="2"><A href="process.php?SearchPattern=<?=trim($Result[0])?>" class="F1"><?=$Result[1]?></a></font>
                  <table id="<?=$TableId?>" style="display=none" cellspacing="0" cellpadding="0">
            <?
              ListChildTree($ChildDepartment,$BaseNum);//递归调用函数本身来显示其他孩子节点
            }//end if?>
             </table>
            <?}//end while
           }//end function?>
<html>
<head>
<title>无限级菜单测试</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<link rel="stylesheet" href="../text.css" type="text/css">
<script language="javascript">
function expands(expid,picid) //显示图片张合的Js
{   //    alert("this.document.all["+expid+"].style.display");
  if(this.document.all[expid].style.display=="none")
  { this.document.all[expid].style.display="block";
    this.document.all[picid].src="leaf.gif";

  }
  else
  {
    this.document.all[expid].style.display="none";
    this.document.all[picid].src="parent.gif";
  }
}
</script>
</head>

<body bgcolor="#FFFFFF" text="#000000">
<?
  require("do_mySql.php");
$Tree = new DB_Sql;
$Tree->connect();//连接数据库,可根据需要换成自己的代码

  $Sql="select DepartmentId,DepartmentName from test where length(DepartmentId)=3";//提出最上层节点(祖宗节点),根据需要自己修改
  $Result=$Tree->query_first($Sql);
?>
<div align="center">                         
  <center>                         
  <table border="1" cellpadding="0" cellspacing="0" width="766" bordercolor="#DDCF90" height="392">                         
    <tr>                         
      <td valign="top">                     
        <div align="center">         
          <table border="0" cellpadding="0" cellspacing="0" width="372">         
            <tr>         
              <td width="368"><a onclick="javascript:expands('dwtop','dwimg')" style="cursor:hand"><span align="absmiddle"> <img id="dwimg" SRC="parent.gif" border="0" align="absmiddle" width="35" height="17"></span></a><font size="2"><a href="process.php?SearchPattern=<?=$Result[0]?>"><?=$Result[1]?></a></font>                                                                                      
        <table id="dwtop" style="display=none" cellspacing="0" cellpadding="0">
         <?        
               $FirstDepartment=$Result[0];
               $BaseNum=strlen($FirstDepartment)/3;//计算层数,其实这个有点多余,因为其必为第一层
               $SearchPattern=$FirstDepartment."___";    //设置查找条件       
               ListChildTree($SearchPattern,$BaseNum);        //显示祖宗节点的孩子节点
         ?>
        </table>
        </td>
         </tr>
        </table>
       </div>
      </td>
     </tr>
    </table>
       </center>
   </div>

</body>
</html>

<?/* 表结构的设计

由于是测试表设计得非常的简单:

CREATE TABLE test (
  id mediumint(8) unsigned NOT NULL auto_increment, #流水号
  DepartmentId varchar(100) NOT NULL default '',    #单位代号
  DepartmentName varchar(100) NOT NULL default '',  #单位名称
  KEY id (id)  
)

数据插入的代码我在这里就不那出来给大家了(很容易写,相信大家都能写出来)

数据表的规则为:

001为第一级(如果999个不够,请自行添加)
001001为001的第一个子节点,001002为001的第二个子节点
001001001为001001的第一个子节点,以此类推……

我这里只设置了一个"祖宗"(001),所以在程序中就直接调用了,可根据需要自己来设置,并对代码作简单的修改即可!

好了,就到这里了,如果大家有问题欢迎和我探讨!最好祝大家今天工作愉快!
先吸颗烟在睡觉!好累!(因为刚刚写了一个webFtp,如果哪位兄弟姐妹需要请mail我)
*/

?>

PHP 相关文章推荐
PHP利用COM对象访问SQLServer、Access
Oct 09 PHP
PHP Class&amp;Object -- PHP 自排序二叉树的深入解析
Jun 25 PHP
php配置php-fpm启动参数及配置详解
Nov 04 PHP
PHP封装的一个支持HTML、JS、PHP重定向的多功能跳转函数
Jun 19 PHP
php遍历目录方法小结
Mar 10 PHP
php递归遍历多维数组的方法
Apr 18 PHP
全面解读PHP的人气开发框架Laravel
Oct 15 PHP
PHP数据库连接mysql与mysqli对比分析
Jan 04 PHP
php获取POST数据的三种方法实例详解
Dec 20 PHP
php 浮点数比较方法详解
May 05 PHP
thinkPHP5框架auth权限控制类与用法示例
Jun 12 PHP
php实现文件上传基本验证
Mar 04 PHP
综合图片计数器
Oct 09 #PHP
php,不用COM,生成excel文件
Oct 09 #PHP
PHP中GET变量的使用
Oct 09 #PHP
一个ORACLE分页程序,挺实用的.
Oct 09 #PHP
通过ICQ网关发送手机短信的PHP源程序
Oct 09 #PHP
搜索引擎技术核心揭密
Oct 09 #PHP
输出控制类
Oct 09 #PHP
You might like
谈谈PHP语法(3)
2006/10/09 PHP
PHP输出九九乘法表代码实例
2015/03/27 PHP
论坛特效代码收集(落伍转发-不错)
2006/12/02 Javascript
js实现快速分享功能(你的文章分享工具)
2013/06/25 Javascript
JavaScript获取某年某月的最后一天附截图
2014/06/23 Javascript
node.js中的require使用详解
2014/12/15 Javascript
基于jQuery的JavaScript模版引擎JsRender使用指南
2014/12/29 Javascript
数据分析软件之FineReport教程:[5]参数界面JS(全)
2015/08/13 Javascript
JS判断字符串字节数并截取长度的方法
2016/03/05 Javascript
Bootstrap按钮下拉菜单组件详解
2016/05/10 Javascript
深入分析javascript中console命令
2016/08/14 Javascript
React实现双向绑定示例代码
2016/09/19 Javascript
浅谈javascript:两种注释,声明变量,定义函数
2016/09/29 Javascript
利用CSS、JavaScript及Ajax实现图片预加载的三大方法
2017/01/22 Javascript
jQuery插件zTree实现的基本树与节点获取操作示例
2017/03/08 Javascript
vue.js实现带日期星期的数字时钟功能示例
2018/08/28 Javascript
记一次webapck4 配置文件无效的解决历程
2018/09/19 Javascript
vue cli3.0结合echarts3.0与地图的使用方法示例
2019/03/26 Javascript
vue 使用鼠标滚动加载数据的例子
2019/10/31 Javascript
pandas 取出表中一列数据所有的值并转换为array类型的方法
2018/04/11 Python
python如何求解两数的最大公约数
2018/09/27 Python
python如何实现一个刷网页小程序
2018/11/27 Python
Python中变量的输入输出实例代码详解
2019/07/28 Python
Python定义一个函数的方法
2020/06/15 Python
举例讲解Python装饰器
2020/12/24 Python
移动端HTML5 input常见问题(小结)
2020/09/28 HTML / CSS
微软香港官网及网上商店:Microsoft HK
2016/09/01 全球购物
Superdry极度干燥美国官网:英国制造的服装品牌
2018/11/13 全球购物
python+selenium小米商城红米K40手机自动抢购的示例代码
2021/03/24 Python
银行学习十八大感想
2014/01/11 职场文书
文案策划求职信
2014/03/18 职场文书
欢度春节标语
2014/07/01 职场文书
医院员工辞职信范文
2015/05/12 职场文书
三八红旗手主要事迹材料
2015/11/04 职场文书
2016年度先进班组事迹材料
2016/03/01 职场文书
25句企业管理语录:助你迅速打开思路,句句经典!
2020/01/14 职场文书