PHP无限极分类技术

什么是无限分类?

无限分类就是一个分类下面可以创建多个子类,而其子类下面亦可以创建不同子类,如此往复,没有终点;

PHP无限极分类技术_第1张图片

分类在生活中的体现

PHP无限极分类技术_第2张图片

实现方法

以父ID实现的无限分类
使用递归算法,表中一个字段id,一个字段pid(父id);这样可以根据WHERE id=pid来查出上一级的内容,然后一层一层的查出最上面的内容,运用递归至顶层。

递归就是一种程序自身调用自身的一种编程技巧

递归的简单实例:

function digui($i=1) {
        echo $i;
        $i++;
        if ($i<10) {
            $this->digui($i);
        }
    }

用for循环也可以实现,所以说明递归就是一个循环;

递归无限分类原理

每一个分类都需要记录它的父级id,当为顶级分类时,父级id为0;这样无论哪个分类,都可以通过父级id一层层的去查明它所有的父级,以便清楚知道它所属何种分类,层级深度为几。

PHP无限极分类技术_第3张图片

由这张图可以看出这个分类的层级深度是4;

数据表设计

PHP无限极分类技术_第4张图片

表中需要说明一下cateorder排序字段:当层级深度是一样的时候我们让哪个数据在前哪个数据在后,这个时候就可以利用这个字段,设置一个数字,小的排在前面,大的排在后面;

应用场景

一般在我们后台功能模块里面的分类需要运用

PHP无限极分类技术_第5张图片

无限分类代码实现

第一种:递归

function digui($pid=0,$arr=array(),$level=''){
        $where['pid'] = $pid;
        $model = M('cate');
        $data = $model->where($where)->select();
        $level++;
        if ($data) {
            foreach ($data as $v) {
                $v['level'] = $level;
                $v['name'] = '|'.str_repeat('--',$level).$v['name'];
                $arr[] = $v;
                $arr = $this->digui($v['id'],$arr,$level);
            }
        }
        return $arr;
    }

视图层代码


第二种:将分类表重构数组以无限极目录树的形式展现

        $category = M('cate')->select();
        //以主键ID为下标重构数组
        foreach ($category as $k=>$v) {
            $arr[$v['id']] = $v;
        }
        //无限极分类数据树形结构化
        $tree = array();
        foreach($arr as $arrs){
            if(isset($arr[$arrs['pid']])){
                $arr[$arrs['pid']]['menu'][] = &$arr[$arrs['id']];
            }else{
                $tree[] = &$arr[$arrs['id']];
            }
        }

前台模板循环调出分类菜单


你可能感兴趣的:(PHP无限极分类技术)