无限级分类完成思路

本文探讨了无限级分类在商品分类中的应用,重点介绍了其实现原理——递归调用函数,根据传入参数变化获取不同级别的分类数据。同时,文章强调了数据库表设计的关键,子类需要包含父类ID,顶级分类的parent_id为0。通过示例展示的表结构(cat_id, cat_name, parent_id)和代码实现,清晰地解释了一个简单无限级分类系统的工作流程。" 113201305,10547764,解决MySQL导入错误2013:Lost connection during query,"['MySQL问题', '数据库导入', '配置参数']
摘要由CSDN通过智能技术生成

限级分类多用于商品的分类

其原理就是调用函数体本身,通过传递的参数不同,则查出的数据不同

无限级分类对表的设计有着要求,子类中必须有父类的id,如果是顶级分类id则父级id(parent_id)的值为0

表字段:

 cat_id(自增id)     cat_name(名称)    parent_id(父类id)

代码实现:

<?php
  //无限级分类
    public function always_category($path=0)
    {
        $data = Db::table('category')->field(['cat_id','cat_name','parent_id'])->where(['parent_id'=>$path])->select();
        foreach($data as $key=>$val)
        {
            $son = $this->always_category($val['cat_id']);
            if(!empty($son))
            {
                $data[$key]['son'] = $son;
            }
        }
        return $data;
    }
?>

查出的结果格式如下:

 Array
(
    [0] => Array
        (
            [cat_id] => 28
            [cat_name] => 手机、数码
            [parent_id] => 0
            [son] => Array
                (
                    [0] => Array
                        (
                            [cat_id] => 29
                            [cat_name] => 手机通讯
                            [parent_id] => 28
                            [son] => Array
                                (
                                    [0] => Array
                                        (
                                            [cat_id] => 30
                                            [cat_name] => 618手机
                                            [parent_id] => 29
                                        )

                                    [1] => Array
                                        (
                                            [cat_id] => 31
                                            [cat_name] => 手机
                                            [parent_id] => 29
                                        )

                                    [2] => Array
                                        (
                                            [cat_id] => 32
                                            [cat_name] => 对讲机
                                            [parent_id] => 29
                                        )

                                )

                        )

                    [1] => Array
                        (
                            [cat_id] => 33
                            [cat_name] => 数码配件
                            [parent_id] => 28
                            [son] => Array
                                (
                                    [0] => Array
                                        (
                                            [cat_id] => 34
                                            [cat_name] => 储存卡
                                            [parent_id] => 33
                                        )

                                    [1] => Array
                                        (
                                            [cat_id] => 35
                                            [cat_name] => 读卡器
                                            [parent_id] => 33
                                        )

                                )

                        )

                )

        )

    [1] => Array
        (
            [cat_id] => 36
            [cat_name] => 图书、音影
            [parent_id] => 0
            [son] => Array
                (
                    [0] => Array
                        (
                            [cat_id] => 38
                            [cat_name] => 教育
                            [parent_id] => 36
                            [son] => Array
                                (
                                    [0] => Array
                                        (
                                            [cat_id] => 41
                                            [cat_name] => 考试
                                            [parent_id] => 38
                                        )

                                    [1] => Array
                                        (
                                            [cat_id] => 42
                                            [cat_name] => 外语学习
                                            [parent_id] => 38
                                        )

                                )

                        )

                    [1] => Array
                        (
                            [cat_id] => 37
                            [cat_name] => 文艺
                            [parent_id] => 36
                            [son] => Array
                                (
                                    [0] => Array
                                        (
                                            [cat_id] => 39
                                            [cat_name] => 小说
                                            [parent_id] => 37
                                        )

                                    [1] => Array
                                        (
                                            [cat_id] => 40
                                            [cat_name] => 文学
                                            [parent_id] => 37
                                        )

                                )

                        )

                )

        )

    [2] => Array
        (
            [cat_id] => 43
            [cat_name] => 家用电器
            [parent_id] => 0
            [son] => Array
                (
                    [0] => Array
                        (
                            [cat_id] => 44
                            [cat_name] => 大家电/厨房家电
                            [parent_id] => 43
                            [son] => Array
                                (
                                    [0] => Array
                                        (
                                            [cat_id] => 45
                                            [cat_name] => 消毒柜
                                            [parent_id] => 44
                                        )

                                )

                        )

                    [1] => Array
                        (
                            [cat_id] => 46
                            [cat_name] => 生活电器
                            [parent_id] => 43
                            [son] => Array
                                (
                                    [0] => Array
                                        (
                                            [cat_id] => 47
                                            [cat_name] => 电风扇
                                            [parent_id] => 46
                                        )

                                )

                        )

                )

        )

)


一个简单的无限级分类就完成了!

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值