实现无限极分类(使用递归)

商品分类

这里写图片描述
$data : 所有的分类数据

$pid : 父类id

$level : 是用于区分层级关系定义的变量

function getTree($data,$pid=0,$level=0){
    static $arr = array();
    foreach($data as $key => $v){
        if($pid == $v['pid']){
            $v['level'] = $level; //分级操作
            $arr[] = $v;  //将满足的数据存入的空数组里面
            getTree($v,$v['pid'],$level+1); 
            //递归查找自己下面是否还有下一级
        }
    }
    return $arr;
}

递归删除:(根据业务需求制定)

function getDel($data,$id){
    static $arr = array();
    foreach($data as $key => $v){
        if($id == $v['pid']){
            $arr[] = $v;
            getDel($data,$v['id']);
        }
    }
    return $arr;
}

使用无限极分类可以实现:
① 权限的分类
② 商品的分类
③ 栏目的分类
…….


<?php
//设置字符集
header('content-type:text/html;charset=utf-8');

/**
 * 无限极分类
 * @param   $list array()
 * return array
 */
//无限极分类,实现具有父子关系的数据分类
function category($arr,$pid=0,$level=0){
    //定义一个静态变量,存储一个空数组,用静态变量,是因为静态变量不会被销毁,会保存之前保留的值,普通变量在函数结束时,会死亡,生长周期函数开始到函数结束,再次调用重新开始生长
    //保存一个空数组
    static $list=array();
    //通过遍历查找是否属于顶级父类,pid=0为顶级父类,
    foreach($arr as $value){
        //进行判断如果pid=0,那么为顶级父类,放入定义的空数组里
        if($value['pid']==$pid){
            //添加空格进行分层
            $arr['level']=$level;
            $list[]=$value;
            //递归点,调用自身,把顶级父类的主键id作为父类进行再调用循环,空格+1
            category($arr,$value['id'],$level+1);
        }
    }
    return $list;//递归出口
}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值