无限级别菜单的实现


<? /* 看到很多朋友问过无限级别菜单的的问题(其实理论上还是有级别的,毕竟要受到个方便的条件的限制,比如: 数据库字段的类型等),我曾经用老大(唠叨)提供的代码写出来过无限级别的菜单,但是感觉效果不是很好(视觉上),于是趁着"夜深人静"就写这个"无限制级别的菜单",其实道理很简单,主要是数据表的设计,还有递归方法的使用(如果有时间我会用中值排序法来做),我会在下面给出数据结构的设计(非常简单),这里我没有加上竖直的虚线(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我)
*/


?>



相关阅读:
C# 中的 @ 符号的使用及注意事项
XP上无法应用Win2008的AD组策略解决办法
javascript 跳转代码集合
如何用Exmap查看进程的内存占用情况
asp 在线备份与恢复sqlserver数据库的代码
MySQL 编码机制
Mobile Robot Programming Toolkit (MRPT)
css 等宽导航栏设计技巧
关于MYSQL 远程登录的授权方法 命令
在登录触发器错误情况下连接SQL Server的方法
Session设置过期时间的几种方式分享
javascript的事件描述
对所有SMTP队列禁用出站邮件
使用SimpleXML需要注意的问题
快速导航
PHP MySQL HTML CSS JavaScript MSSQL AJAX .NET JSP Linux Mac ASP 服务器 SQL jQuery C# C++ java Android IOS oracle MongoDB SQLite wamp 交通频道 作文范文 你也随他一起流失...... 不知道應該咋辦 雨落惆怅,青色兰花伞的身影 我和妈妈有个小约定作文450字 2010年虎年春联集锦 与你相遇,好幸运 雨之春意 表达思念亲人的诗句 我心中的那朵芬芳,静静流淌……600字 当初不该与你那么近,曾经不该与你那么好 小学六年级作文500字:难忘的一次掌声 自己的观音读后感500字 想你,在你远行的日子里! 会计划半年工作总结4 县委书记在人大会议党员代表会议上的讲话 [Lovesong]作文1200字 你以为一辈子都不会忘记的人,或许某天也懒得提起 升起心中的太阳作文400字 《羚羊木雕》读书笔记400字 我心中的丰碑作文400字 我的一个压岁红包 医师实习自我鉴定 我最欣赏的一位语文老师 难忘的一件小事——香蕉皮作文650字 感恩节活动策划方案最新 项链(缩写)作文600字 提高简历命中率的技巧 电气工程自动化专业求职信范文 大一迎新晚会策划书 初中初二作文800字:第一次我没放弃 我和孙悟空做搭档 描写荷花的好词好句好段大全 学校教职工大会开幕词 经典散文:努力的意义是赢自己 心死的句子 缘过、物是人非 关于攀岩的作文800字 2015河北中考作文题目预测及范文:年轮 四强专题二心得体会 你已经逝去的回忆 在我的心中摇摆不定 端午节300字作文 铁树开花作文1000字 《神奇的魔术师》阅读答案 岁月残雪,冰藏了谁的忧伤 文艺工作2013年述职报告 献给老师的回忆 食品局2014年工作总结-行政后勤工作总结_行政后勤工作总结 12333培训心得体会 2014年越读越心碎的美文美句摘选 妈妈的厨艺

Copyright © 2016 phpStudy |