注    册
密 码 忘记密码
保存密码         取消
注    册
密 码 忘记密码
保存密码         取消

我的日志

一个更简单的无限级分类菜单代码

分类:PHP基础应用
2007.1.3 14:40 作者:辉老大 | 评论:2 | 阅读:0

首先要感谢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代码如下:

<?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 '&nbsp;
';
              }
             echo 
$rows['name'].'<br>';
            }
       }

       
//创建析构函数,作用:关闭数据库连接
       
public function __destruct(){
           return 
mysql_close();
       }
   }
  
$db=new menu();//生成实例
  
$db->menulist();//调用方法生成菜单
?> 

你可以通过这个链接引用该篇文章:http://leehui1983.bokee.com/viewdiary.14431122.html

            永恒的话题:PHP... 上一篇 | 下一篇 解决中英文字符串长...

我的广告

我的搜索

文章评论

添加评论

已有2位对此文章感兴趣的网友发表了看法 【点击查看】
昵  称:  主  页: (选填)
验证码: 

定制广告