TP5.1实现无限级分类

1.解决思路

  1. 首先先定一张分类表。包含如下几个字段 (自增id,类目名称,父类id,子类id)
  2. 写 2 个类,1个类查询总数据,另一个类写方法(利用 foreach 循环遍历)

2.贴代码

class Tree extends Model
{
    //输出所有内容
    public function tree(){
        $obj = new Tree();
        $tree_list= $obj->select();
        return $this->sorts($tree_list);
    }

    //创建方法  $data参数是数据库所有数据  $pid参数是数据库pid  $le参数是为了区分显示级别的
    public function sorts($data,$pid=0,$level=0){
        //创建一个静态数组保存数据
        static $arr = array();
        //循环出所有的有关数据保存进数组
        foreach($data as $k => $v){
            //当第一循环是pid==0 因为上面已经设置pid==0
            if($v['pid']==$pid){
                //这里是为了区分级别
                $v['level']=$level;
                //将有关数据保存如数据
                $arr[]=$v;
                //为了将有关数据保存数据,这里使用递归
                $this->sorts($data,$v['id'],$level+1);
            }
        }
        //将最后的内容输出返回
        return $arr;
    }
}

3.接口输出数据,完成。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值