zoukankan      html  css  js  c++  java
  • 无限级分类

    借用一位前辈的思路和风格,将代码整理在这里

    <?php
    
    /**
     * 无限级分类 类
     */
    class Category{
    
        /**
         * 返回一维数组
         * @param  [type]  $cate  要递归的数组
         * @param  string  $html  子级分类前要显示的缩进符号。默认 '─'
         * @param  integer $pid   父级分类ID。默认为 0,表示顶级分类
         * @param  integer $level level级,配合 $html 显示足够的缩进。默认为 1,表示顶级分类
         * @return [type]         [description]
         */
        static public function unlimitedForLevel($cate, $html = '─', $pid = 0, $level = 1){
            $arr = array();
            foreach($cate as $v){
                if($v['pid'] == $pid){
                    $v['level'] = $level;
                    $v['html'] = str_repeat($html, $level - 1);
                    $arr[] = $v;
                    $arr = array_merge($arr, $this->unlimitedForLevel($cate, $html, $v['id'], $level + 1));
                }
            }
            return $arr;
        }
    
        /**
         * 返回多维数组
         * @param  [type]  $cate 要递归的数组
         * @param  string  $name 子级分类在父分类数组中的 key
         * @param  integer $pid  父级分类ID。默认为0,表示顶级分类
         * @return [type]        [description]
         */
        static public function unlimitedForlayer($cate, $name = 'child', $pid = 0){
            $arr = array();
            foreach($cate as $v){
                if( $v['pid'] == $pid){
                    $v[$name] = self::unlimitedForlayer($cate, $name, $v['id']);
                    $arr[] = $v;
                }
            }
            return $arr;
        }
    
        /**
         * 传递子分类ID返回所有父级分类
         * @param  [type] $cate 要递归的数组
         * @param  [type] $id   子分类ID
         * @return [type]       [description]
         */
        static public function getParents($cate, $id){
            $arr = array();
            foreach($cate as $v){
                if($v['id'] == $id){
                    $arr[] = $v;
                    $arr = array_merge(self::getParents($cate, $v['pid']), $arr);
                }
            }
            return $arr;
        }
    
        /**
         * 传递父级分类ID返回所有子分类ID
         * @param  [type] $cate 要递归的数组
         * @param  [type] $pid  父级分类ID
         * @return [type]       [description]
         */
        static public function getChildrenId($cate, $pid){
            $arr = array();
            foreach($cate as $v){
                if($v['pid'] == $pid){
                    $arr[] = $v['id'];
                    $arr = array_merge($arr, self::getChildrenId($cate, $v['id']));
                }
            }
            return $arr;
        }
    
        /**
         * 传递父级分类ID返回所有子级分类
         * @param  [type] $cate 要递归的数组
         * @param  [type] $pid  父级分类ID
         * @return [type]       [description]
         */
        static public function getChildren($cate, $pid){
            $arr = array();
            foreach($cate as $v){
                if($v['pid'] == $pid){
                    $arr[] = $v;
                    $arr = array_merge($arr, self::getChildren($cate, $v['id']));
                }
            }
            return $arr;
        }
    
    }
    ?>

      

  • 相关阅读:
    SQL Server的AlwaysOn错误19456和41158
    kvm上的Linux虚拟机使用virtio磁盘
    利用HAProxy代理SQL Server的AlwaysOn辅助副本
    KVM安装部署
    ola.hallengren的SQL Server维护脚本
    在单链表的第i个位置后插入一个节点(阿里+腾讯等面试题总结)
    怎么发现RAC环境中&#39;library cache pin&#39;等待事件的堵塞者(Blocker)?
    php unserialize 返回false的解决方法
    千万别让这些举动断送了你的职业前程-好文共分享
    Android开发:仿美团下拉列表菜单,帮助类,复用简单
  • 原文地址:https://www.cnblogs.com/mingc/p/6804963.html
Copyright © 2011-2022 走看看