关于PHP无限极分类

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于PHP无限极分类相关的知识,希望对你有一定的参考价值。

先有一个表存无限极分类

id cate_name parent_id
1 ... 0
2 ... 0
3 ... 1
4 ... 3
5 ... 4
6 ... 4
7 ... 1
8 ... 3

哪位同学帮我写一个函数,取得一个三维数组,如下:
即:把所有的有子类的,都组成1个二维数组。就是父ID为0的有(1,2)两个子类,父ID为1的有(3,7)两个子类,父ID为3的有(4,8)两个子类,父ID为4的有(5,6)两个子类。不知道有没有说清楚,求大神们江湖救急!!!
array(
'0'=>array(
'0'=>array('id'=>'1','name'=>'..'),
'1'=>array('id'=>'2','name'=>'..'),),
'1'=>array(
'0'=>array('id'=>'3','name'=>'..'),
'1'=>array('id'=>'7','name'=>'..'),),
'3'=>array(
'0'=>array('id'=>'4','name'=>'..'),
'1'=>array('id'=>'8','name'=>'..'),),
'4'=>array(
'0'=>array('id'=>'5','name'=>'..'),
'1'=>array('id'=>'6','name'=>'..'),),
)

function genTree5($items)  
    foreach ($items as $item) 
        $items[$item['pid']]['son'][$item['id']] = &$items[$item['id']]; 
    return isset($items[0]['son']) ? $items[0]['son'] : array(); 

超级爽的函数,格式可能不一样,但肯定有用,树状结构的输出

参考技术A 先从数据库取出数据,然后通过php 的array函数做重组便可。。。仅供参考,不喜勿喷 参考技术B foreach,$key=array($value)

php实现无限极分类

生成无限极分类

private function GetTree($arr,$pid,$step){
    global $tree;
    foreach($arr as $key=>$val) {
        if($val[‘pid‘] == $pid) {
            $flg = str_repeat(‘└―‘,$step);
            $val[‘name‘] = $flg.$val[‘name‘];
            $tree[] = $val;
            $this->GetTree($arr , $val[‘cid‘] ,$step+1);
        }
    }
    return $tree;
}
调用:
$newarr = $this->GetTree($arr, 0, 0);

根据子类id查找出所有父级分类信息

方法一:

 //$arr 所有分类列表
 //$id 父级分类id
public static function get_parent_list($arr,$id)
{
        static $list=array();
        foreach($arr as $u)
       {
            if($u[‘id‘]== $id)
            {   //父级分类id等于所查找的id
                $list[]=$u;
                if($u[‘parent_id‘]>0)
                {
                    self::get_parent_list($arr,$u[‘parent_id‘]);
                }
            }
        }
       return $list;
 }                

方法二:递归查询取分类信息

// $id  要查询的 子栏目id 
public static function get_parents($id)
{
        static $list = [];
        // Yii2 框架 
        $cat_data = Category::findOne($id)->toarray();
        if($cat_data)
       {
            $list[] = $cat_data;
            $id = $cat_data[‘parent_id‘];
             if($cat_data[‘parent_id‘] > 0)
            {
                self::get_parents($id);
             }
        }
        return $list;
}     

 

根据父id获得所有下级子类id的数据

//$id = 父级id  $array = 所有分类
public function getSon($id,$array)
{
        static $list;
        foreach ($array as $k => $v)
        {
            if($v[‘parent_id‘] == $id)
            {
                $list[] = $array[$k];
                self::getSon($v[‘id‘],$array);
            }
        }
        return $list;
}

 



以上是关于关于PHP无限极分类的主要内容,如果未能解决你的问题,请参考以下文章

PHP无限极分类详谈

php递归无限极分类怎么弄

什么是 无限极分类???(PHP。数据库)

PHP使用引用实现无限极分类

php无限极分类以及递归(thinkphp)

手把手教你用php实现无限极分类功能