当前位置: 首页 > 编程笔记 >

PHP超牛逼无限极分类生成树方法

华建同
2023-03-14
本文向大家介绍PHP超牛逼无限极分类生成树方法,包括了PHP超牛逼无限极分类生成树方法的使用技巧和注意事项,需要的朋友参考一下

你还在用浪费时间又浪费内存的递归遍历无限极分类吗,看了该篇文章,我觉得你应该换换了。

这是我在OSChina上看到的一段非常精简的PHP无限极分类生成树方法,巧在引用,整理分享了。


function generateTree($items){

    $tree = array();

    foreach($items as $item){

        if(isset($items[$item['pid']])){

            $items[$item['pid']]['son'][] = &$items[$item['id']];

        }else{

            $tree[] = &$items[$item['id']];

        }

    }

    return $tree;

}

$items = array(

    1 => array('id' => 1, 'pid' => 0, 'name' => '安徽省'),

    2 => array('id' => 2, 'pid' => 0, 'name' => '浙江省'),

    3 => array('id' => 3, 'pid' => 1, 'name' => '合肥市'),

    4 => array('id' => 4, 'pid' => 3, 'name' => '长丰县'),

    5 => array('id' => 5, 'pid' => 1, 'name' => '安庆市'),

);

print_r(generateTree($items));

可以看到下面打印的结果:


Array

(

    [0] => Array

        (

            [id] => 1

            [pid] => 0

            [name] => 安徽省

            [son] => Array

                (

                    [0] => Array

                        (

                            [id] => 3

                            [pid] => 1

                            [name] => 合肥市

                            [son] => Array

                                (

                                    [0] => Array

                                        (

                                            [id] => 4

                                            [pid] => 3

                                            [name] => 长丰县

                                        )

 

                                )

 

                        )

 

                    [1] => Array

                        (

                            [id] => 5

                            [pid] => 1

                            [name] => 安庆市

                        )

 

                )

 

        )

 

    [1] => Array

        (

            [id] => 2

            [pid] => 0

            [name] => 浙江省

        )

 

)


上面生成树方法还可以精简到5行:

function generateTree($items){

    foreach($items as $item)

        $items[$item['pid']]['son'][$item['id']] = &$items[$item['id']];

    return isset($items[0]['son']) ? $items[0]['son'] : array();

}

上面这种无限极分类数据树形结构化的方法值得借鉴。但是我觉得这段代码实际用途并不明显啊,你想取出格式化的树形数据还是要递归啊:


/**

 * 如何取数据格式化的树形数据

 */

$tree = generateTree($items);

function getTreeData($tree){

    foreach($tree as $t){

        echo $t['name'].'<br>';

        if(isset($t['son'])){

            getTreeData($t['son']);

        }

    }

}

getTreeData($tree);

 类似资料:
  • 本文向大家介绍PHP实现无限极分类生成分类树的方法,包括了PHP实现无限极分类生成分类树的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了PHP实现无限极分类生成分类树的方法。分享给大家供大家参考,具体如下: 现在的分类数据库设计基本都是:每一个分类有一个id主键字段,一个pid指向父类的id,这样便可实现无限级分类,取出的数据就是如下的格式: 不多说,直接上处理代码: 测试运行: 运

  • 本文向大家介绍浅谈PHP无限极分类原理,包括了浅谈PHP无限极分类原理的使用技巧和注意事项,需要的朋友参考一下 1.递归:程序调用自身的编程技巧称为递归 2.案例: 3.global 4.static 5.说白了递归就是一个循环,用循环实现和递归实现是同样的效果。 以上所述是小编给大家介绍的PHP无限极分类原理详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也

  • 本文向大家介绍php无限极分类递归排序实现方法,包括了php无限极分类递归排序实现方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了php无限极分类递归排序实现方法。分享给大家供大家参考。具体实现方法如下: 希望本文所述对大家的PHP程序设计有所帮助。

  • 本文向大家介绍创建无限极分类树型结构的简单方法,包括了创建无限极分类树型结构的简单方法的使用技巧和注意事项,需要的朋友参考一下 先上效果图 顶级分类其实就是一级分类,二级分类也叫作一级分类的子分类,在这个基础上,子分类还可以拥有子分类,这样就构成了无限极分类。 接下来看具体实现的代码: 一、在控制器中按字段查询,查询出所有分类信息(id:该分类的ID值,cate_name:该分类的名称,pid:父

  • 本文向大家介绍PHP无限极分类函数的实现方法详解,包括了PHP无限极分类函数的实现方法详解的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了PHP无限极分类函数的实现方法。分享给大家供大家参考,具体如下: 在开发程序的时候,有时候,我们需要获取所有栏目(包括一级栏目、二级栏目、三级栏目等等),并按照父子关系形成树型结构。可以采取使用递归或者通过引用方式(php中引用类似C或者C++中的指针,

  • 本文向大家介绍PHP实现无限极分类图文教程,包括了PHP实现无限极分类图文教程的使用技巧和注意事项,需要的朋友参考一下 一般来说实现无限极分类都是使用递归或者迭代的方式,小伙伴们看下本文的实现方式吧。 1,数据库设计: 2,代码: 3,效果图: 是不是很简单呢,小伙伴们可以直接拿去用哈,不收版权费^_^