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


Posted in PHP onMay 11, 2015

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

这是我在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的分页功能
Mar 21 PHP
用穿越火线快速入门php面向对象
Feb 22 PHP
使用Sphinx对索引进行搜索
Jun 25 PHP
windows7下安装php的imagick和imagemagick扩展教程
Jul 04 PHP
php递归函数三种实现方法及如何实现数字累加
Aug 07 PHP
php 升级到 5.3+ 后出现的一些错误,如 ereg(); ereg_replace(); 函数报错
Dec 07 PHP
PHP实现图片上传并压缩
Dec 22 PHP
PHP使用PDO操作数据库的乱码问题解决方法
Apr 08 PHP
Discuz论坛密码与密保加密规则
Dec 19 PHP
phpmyadmin下载、安装、配置教程
May 16 PHP
PHP下 Mongodb 连接远程数据库的实例代码
Aug 30 PHP
php反序列化长度变化尾部字符串逃逸(0CTF-2016-piapiapia)
Feb 15 PHP
php以fastCGI的方式运行时文件系统权限问题及解决方法
May 11 #PHP
PHP获取当前日期和时间及格式化方法参数
May 11 #PHP
PHP借助phpmailer发送邮件
May 11 #PHP
PHP date函数常用时间处理方法
May 11 #PHP
护卫神php套件 php版本升级方法(php5.5.24)
May 10 #PHP
php.ini中的request_order推荐设置
May 10 #PHP
浅析iis7.5安装配置php环境
May 10 #PHP
You might like
php strrpos()与strripos()函数
2013/08/31 PHP
PHP中mysql_field_type()函数用法
2014/11/24 PHP
PHP多线程编程之管道通信实例分析
2015/03/07 PHP
使用PHPCMS搭建wap手机网站
2015/09/20 PHP
PHP中-&gt;和=&gt;的含义及使用示例解析
2020/08/06 PHP
JS实现点击下载的小例子
2013/07/10 Javascript
js转义字符介绍
2013/11/05 Javascript
将HTML的左右尖括号等转义成实体形式的两种实现方式
2014/05/04 Javascript
jquery 中的each()跳出循环的语句
2014/05/23 Javascript
jQuery实现的原图对比窗帘效果
2014/06/15 Javascript
javascript数组常用方法汇总
2016/09/10 Javascript
学习Node.js模块机制
2016/10/17 Javascript
JS实现的透明度渐变动画效果示例
2018/04/28 Javascript
jQuery实现鼠标移到某个对象时弹出显示层功能
2018/08/23 jQuery
JavaScript栈和队列相关操作与实现方法详解
2018/12/07 Javascript
Vue注册组件命名时不能用大写的原因浅析
2019/04/25 Javascript
[05:46]DOTA2英雄梦之声_第18期_陈
2014/06/20 DOTA
python自动截取需要区域,进行图像识别的方法
2018/05/17 Python
Python根据欧拉角求旋转矩阵的实例
2019/01/28 Python
keras 权重保存和权重载入方式
2020/05/21 Python
Scrapy 配置动态代理IP的实现
2020/09/28 Python
python asyncio 协程库的使用
2021/01/21 Python
CSS3实现王者匹配时的粒子动画效果
2019/04/12 HTML / CSS
香港草莓网土耳其网站:Strawberrynet TR
2017/03/02 全球购物
我们是伦敦女孩:WalG
2018/01/08 全球购物
如果NULL定义成#define NULL((char *)0)难道不就可以向函数传入不加转换的NULL了吗
2012/02/15 面试题
计算机应用与科学个人的自我评价
2013/11/15 职场文书
学前教育求职自荐信范文
2013/12/25 职场文书
回门宴答谢词
2014/01/13 职场文书
先进个人事迹材料
2014/01/25 职场文书
多媒体编辑专业毕业生求职信
2014/06/13 职场文书
违反单位工作制度检讨书
2014/10/25 职场文书
青少年法制教育心得体会
2016/01/14 职场文书
年终奖金发放管理制度,中小企业适用,拿去救急吧!
2019/07/12 职场文书
使用Pytorch训练two-head网络的操作
2021/05/28 Python
如何使用SQL Server语句创建表
2022/04/12 SQL Server