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 相关文章推荐
第十二节 类的自动加载 [12]
Oct 09 PHP
PHP+DBM的同学录程序(3)
Oct 09 PHP
php中文验证码实现示例分享
Jan 12 PHP
ThinkPHP关于session的操作方法汇总
Jul 18 PHP
php之readdir函数用法实例
Nov 13 PHP
php站内搜索关键词变亮的实现方法
Dec 30 PHP
php版微信开发之接收消息,自动判断及回复相应消息的方法
Sep 23 PHP
Yii2实现log输出到file及database的方法
Nov 12 PHP
php中类和对象:静态属性、静态方法
Apr 09 PHP
PHP 无限级分类
May 04 PHP
深入理解 PHP7 中全新的 zval 容器和引用计数机制
Oct 15 PHP
浅谈laravel-admin的sortable和orderby使用问题
Oct 03 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读取javascript设置的cookies的代码
2010/04/12 PHP
PHP--用万网的接口实现域名查询功能
2012/12/13 PHP
详解 PHP加密解密字符串函数附源码下载
2015/12/18 PHP
Codeigniter中集成smarty和adodb的方法
2016/03/04 PHP
js玩一玩WSH吧
2007/02/23 Javascript
jQuery 页面载入进度条实现代码
2009/02/08 Javascript
jquery弹出框的用法示例(2)
2013/08/26 Javascript
如何让你的Lightbox支持滚轮缩放及Base64图片
2014/12/04 Javascript
JavaScript实现俄罗斯方块游戏过程分析及源码分享
2015/03/23 Javascript
jQuery+HTML5美女瀑布流布局实现方法
2015/09/21 Javascript
JavaScript精炼之构造函数 Constructor及Constructor属性详解
2015/11/05 Javascript
通过扫描二维码打开app的实现代码
2016/11/10 Javascript
如何判断出一个js对象是否一个dom对象
2016/11/24 Javascript
vue 2.0组件与v-model详解
2017/03/27 Javascript
vue自定义底部导航栏Tabbar的实现代码
2018/09/03 Javascript
详解Vue.js iview实现树形权限表(可扩展表)
2018/09/30 Javascript
JavaScript时间日期操作实例小结【5个示例】
2018/12/22 Javascript
在vue使用clipboard.js进行一键复制文本的实现示例
2019/01/15 Javascript
详解React的回调渲染模式
2020/09/10 Javascript
Django在Win7下的安装及创建项目hello word简明教程
2014/07/14 Python
在Linux系统上通过uWSGI配置Nginx+Python环境的教程
2015/12/25 Python
对于Python中RawString的理解介绍
2016/07/07 Python
Python中使用bidict模块双向字典结构的奇技淫巧
2016/07/12 Python
Python3.x对JSON的一些操作示例
2017/09/01 Python
利用python将图片转换成excel文档格式
2017/12/30 Python
tensorflow实现测试时读取任意指定的check point的网络参数
2020/01/21 Python
HTML5标签与HTML4标签的区别示例介绍
2013/07/18 HTML / CSS
canvas裁剪clip()函数的具体使用
2018/03/01 HTML / CSS
怀旧收藏品和经典纪念品:Betty’s Attic
2018/08/29 全球购物
技术比武方案
2014/05/19 职场文书
工作散漫检讨书
2014/09/16 职场文书
2015元旦文艺汇演主持稿(开场白+结束语)
2014/12/14 职场文书
小学教师党员承诺书
2015/04/27 职场文书
社区扶贫帮困工作总结
2015/05/20 职场文书
教你部署vue项目到docker
2022/04/05 Vue.js
Go语言 详解net的tcp服务
2022/04/14 Golang