首先要感谢terry39的指点,元旦闲来无事,我就把他所讲的原理简单实现一下,这个程序的关键就在于数据表的设计很有特色,不用递归,依靠个简单SQL语句就能列出菜单,看看这个数据表怎么设计的: 数据库字段大概如下: ----------------------------------------------------------------------------------- id 编号 fid 父分类编号 name 分类名 path 分类路径,以 id 为节点,组成类似 ,1,2,3,4, 这样的字符串 ----------------------------------------------------------------------------------
可以假设有如下的数据
id fid name path ---------------------------------------------------- 1 0 分类1 ,1, 2 0 分类2 ,2, 3 1 分类1-1 ,1,3, 4 1 分类1-2 ,1,4, 5 2 分类2-1 ,2,5, 6 4 分类1-2-1 ,1,4,6, ---------------------------------------------------- 这次偷懒,我只用一个页面,好在代码不长,全部代码用类封装的(不是必要,而是自己也想熟悉一下OO,呵呵!),来看看页面代码:
复制代码 代码如下: <?php
/**************************************
页面:menu.php 作者:辉老大 功能:定义数据库操作及生成菜单列表类
**************************************/ class menu{
//创建构造函数,作用:数据库连接并选择相应数据库 public function __construct(){ $dbhost = "localhost"; $dbuser = "root"; $dbpassword = "7529639"; $dbname = "menu"; mysql_connect($dbhost,$dbuser,$dbpassword) or die("error!"); mysql_query("SET NAMES 'GBK'"); mysql_select_db($dbname); }
//执行SQL语句函数 private function query($sql){ return mysql_query($sql); }
//取得结果集数组函数 private function loop_query($result){ return mysql_fetch_array($result); } //列出菜单列表函数 public function menulist(){ $sql="select * from list order by path"; $result=$this->query($sql); while($rows=$this->loop_query($result)){ if(substr_count($rows['path'],',')>2){ for($i=0;$i<(substr_count($rows['path'],',')-2);$i++) echo ' '; } echo $rows['name'].'<br>'; } }
//创建析构函数,作用:关闭数据库连接 public function __destruct(){ return mysql_close(); } } $db=new menu();//生成实例 $db->menulist();//调用方法生成菜单 ?>
 (编辑:焦作站长网)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|