一个更简单的无限级分类菜单代码
作者:bea
首先要感谢terry39的指点,元旦闲来无事,我就把他所讲的原理简单实现一下,这个程序的关键就在于数据表的设计很有特色,不用递归,依靠个简单SQL语句就能列出菜单,看看这个数据表怎么设计的: 数据库字段大概如下: ----------------------------------------------------------------------------------- id编号 fid父分类编号 name分类名 path分类路径,以id为节点,组成类似,1,2,3,
首先要感谢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();//调用方法生成菜单
?>
有用 | 无用
代码如下:
<?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();//调用方法生成菜单
?>
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- 简单采集了yahoo的一些数据
- 用PHPdig打造属于你自己的Google[图文教程]
- php中的一个中文字符串截取函数
- PHP音乐采集(部分代码)
- 一个数据采集类
- phpmyadmin中配置文件现在需要绝密的短语密码的解决方法
- 增加反向链接的101个方法 站长推荐
- Discuz!5的PHP代码高亮显示插件(黑暗中的舞者更新)
- 解决控件遮挡问题:关于有窗口元素和无窗口元素
- 获得Google PR值的PHP代码
- 一键删除顽固的空文件夹 软件下载
- php中通过smtp发邮件的类,测试通过
- php5.2.0内存管理改进
- php中截取字符串支持utf-8
- php中的登陆login
- php中的时间显示
- 解决phpmyadmin中文乱码问题。。。
- php批量删除数据
- mysql 的 like 问题,超强毕杀记!!!