美文网首页
PHP无限极分类技术

PHP无限极分类技术

作者: PHPer_ | 来源:发表于2017-08-22 18:10 被阅读535次

什么是无限分类?

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

分类在生活中的体现

实现方法

以父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一层层的去查明它所有的父级,以便清楚知道它所属何种分类,层级深度为几。

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

数据表设计

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

应用场景

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

无限分类代码实现

第一种:递归

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;
    }

视图层代码

<select>
        <option value="0">顶级分类</option>
        <volist name="data" id="v">
            <option value="{$v.id}">{$v.name}</option>
        </volist>
</select>

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

        $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']];
            }
        }

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

<select style="width: 200px;">
    <volist name="category" id="v">
        <option value="{$v.pid}">一级菜单|-{$v.name}</option>
        <volist name="v['menu']" id="va">
            <option value="{$va.pid}">二级菜单|--{$va.name}</option>
            <volist name="va['menu']" id="val">
                <option value="{$val.pid}">三级菜单|---{$val.name}</option>
            </volist>
        </volist>
    </volist>
</select>

相关文章

  • php实现无限极分类

    一、两种实现php无限极分类 设置原始数据 1. 使用php递归实现php无限极分类 通过foreach循环实现无...

  • PHP无限极分类技术

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

  • PHP 无限极分类

    概述   在实际工作中,经常要用到无限极分类。如导航表等等。到网上一搜php无限极分类,很多,但好多都是一个,并且...

  • PHP无限极分类

    要了解这两种方式具体内容,可以去查看这篇博客: 左右值无限分类实现算法 本文主要提供两种将符合无限极分类格式的二维...

  • php无限极分类

    递归--无限极分类 递归--子孙树转二维数组 可以配合Nestable使用 递归--获取树所有叶子节点 结果1 结...

  • PHP 无限极分类

    1.循环迭代实现无限极分类 输出结果如下: 分析:这个算法利用了循环迭代,将线性结构按照父子关系以树形结构输出,算...

  • php无限分类组件

    PHP系统树图 github项目地址 PHP系统树图可快速的处理无限极分类的业务需求 提供两种不同的数据结构和三种...

  • php 引用算法无限极分类

  • PHP实现无限极分类的两种方式,递归和引用

    PHP实现无限极分类的两种方式,递归和引用 转载叶落无痕123 最后发布于2018-09-19 19:29:03 ...

  • 无限极分类原理与实现

    前言 无限极分类是我很久前学到知识,今天在做一个项目时,发现对其概念有点模糊,所以今天就来说说无限极分类。 首先来...

网友评论

      本文标题:PHP无限极分类技术

      本文链接:https://www.haomeiwen.com/subject/mcildxtx.html