首页 > php代码 > PHP无限级分类菜单实例程序

PHP无限级分类菜单实例程序

在做PHP程序时,经常会遇到设计多级菜单的编程,比如我们常见的三级菜单,首先展示产品的第一级分类,然后展示二级分类,最后再展示产品,这样就构成了三级结构,如果在后台没有一个很好的分类菜单支持,那么去更改数据时是很麻烦的。


最近在做一个内容管理的项目,客户硬要来一个多级分类,其实在许多的开源后台都是无限级的分类,比如phprm.com的后台,而这些分类的数据仅仅只保存到了一个数据表里,只是用源代码进行了关联而已。

而这些关联的数据并不复杂,其实一个优秀的后台设计,应该是无限的分类,这样,在进行二次开发时,不用再单独进行编程了,只要是功能一样,后台添加一个分类就可以了,这样就达到了功能共享了。

一个更简单的无限级分类菜单代码,我就把上面的原理简单实现一下,这个程序的关键就在于数据表的设计很有特色,不用递归,依靠个简单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,

—————————————————-

实现的PHP全部代码用类封装的,不是必要,而是自己也想熟悉一下OO,呵呵!,来看看页面代码:

<?php
/**************************************
页面:menu.php
作者:http://www.phprm.com
功能:定义数据库操作及生成菜单列表类
**************************************/
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);
    }
    //取得phprm.com结果集数组函数
    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(); //调用方法生成菜单
?>

小提示:这样就生成了一个无限级的分类菜单,当然,不仅仅只是应用在菜单上,而且可以应用在产品的分类以及地市区的分类上面,后台的增删改查需要自己小小的去写一下



本文地址:http://www.phprm.com/code/53872.html

转载随意,但请附上文章地址:-)

标签:substr select

相关文章

发表留言