php两种无限分类方法实例

所属分类: 网络编程 / PHP编程 阅读数: 1859
收藏 0 赞 0 分享

一、递归方法

复制代码 代码如下:

$items = array(
array('id'=>1,'pid'=>0,'name'=>'一级11'),
array('id'=>2,'pid'=>0,'name'=>'一级12'),
array('id'=>3,'pid'=>1,'name'=>'二级21'),
array('id'=>4,'pid'=>3,'name'=>'三级31'),
array('id'=>5,'pid'=>1,'name'=>'二级22'),
array('id'=>6,'pid'=>3,'name'=>'三级32'),
array('id'=>7,'pid'=>6,'name'=>'四级41'),
);
$i = 0;
function formatTree($arr, $pid = 0){
$tree = array();
$temp = array();
global $i;
if($arr){
foreach($arr as $k=>$v){
if($v['pid'] == $pid){//
$temp = formatTree($arr, $v['id']);
$temp && $v['son'] = $temp;
$tree[] = $v;
}
}
}
return $tree;
}
print_r(formatTree($items));

二、非递归方法
复制代码 代码如下:

function genTree($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' => '一级11'),
    2 => array('id' => 2, 'pid' => 1, 'name' => '二级21'),
    3 => array('id' => 3, 'pid' => 1, 'name' => '二级23'),
    4 => array('id' => 4, 'pid' => 9, 'name' => '三级31'),
    5 => array('id' => 5, 'pid' => 4, 'name' => '四级43'),
    6 => array('id' => 6, 'pid' => 9, 'name' => '三级32'),
    7 => array('id' => 7, 'pid' => 4, 'name' => '四级41'),
    8 => array('id' => 8, 'pid' => 4, 'name' => '四级42'),
    9 => array('id' => 9, 'pid' => 1, 'name' => '二级25'),
    10 => array('id' => 10, 'pid' => 11, 'name' => '二级22'),
    11 => array('id' => 11, 'pid' => 0, 'name' => '一级12'),
    12 => array('id' => 12, 'pid' => 11, 'name' => '二级24'),
    13 => array('id' => 13, 'pid' => 4, 'name' => '四级44'),
    14 => array('id' => 14, 'pid' => 1, 'name' => '二级26'),
    15 => array('id' => 15, 'pid' => 8, 'name' => '五级51'),
    16 => array('id' => 16, 'pid' => 8, 'name' => '五级52'),
    17 => array('id' => 17, 'pid' => 8, 'name' => '五级53'),
    18 => array('id' => 18, 'pid' => 16, 'name' => '六级64'),
);
print_r(genTree($items));

更多精彩内容其他人还在看

浅析PHP 中move_uploaded_file 上传中文文件名失败

这篇文章主要介绍了PHP 中move_uploaded_file 上传中文文件名失败的原因分析及解决方法 ,需要的朋友可以参考下
收藏 0 赞 0 分享

CentOS7编译安装php7.1的教程详解

这篇文章主要介绍了CentOS7编译安装php7.1的教程详解,非常不错,具有一定的参考借鉴价值 ,需要的朋友可以参考下
收藏 0 赞 0 分享

PHP信号处理机制的操作代码讲解

在本篇文章里小编给大家分享了关于PHP信号处理机制的操作的相关知识点内容,需要的朋友们学习下。
收藏 0 赞 0 分享

ThinkPHP3.2.3框架邮件发送功能图文实例详解

这篇文章主要介绍了ThinkPHP3.2.3框架邮件发送功能,结合图文与实例形式详细分析了基于thinkPHP框架进行邮件发送的相关原理、配置及操作技巧,需要的朋友可以参考下
收藏 0 赞 0 分享

一文掌握PHP Xdebug 本地与远程调试(小结)

这篇文章主要介绍了一文掌握PHP Xdebug 本地与远程调试(小结),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

Laravel路由研究之domain解决多域名问题的方法示例

这篇文章主要介绍了Laravel 路由研究之domain解决多域名问题的方法示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

PHP设计模式之策略模式原理与用法实例分析

这篇文章主要介绍了PHP设计模式之策略模式原理与用法,结合实例形式较为详细的分析了策略模式的概念、原理及php实现与使用策略模式的相关操作技巧,需要的朋友可以参考下
收藏 0 赞 0 分享

php使用lua+redis实现限流,计数器模式,令牌桶模式

这篇文章主要介绍了php使用lua+redis实现限流,计数器模式,令牌桶模式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

Laravel多域名下字段验证的方法

这篇文章主要给大家介绍了关于Laravel多域名下字段验证的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Laravel具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
收藏 0 赞 0 分享

PHP中quotemeta()函数的用法讲解

今天小编就为大家分享一篇关于PHP中quotemeta()函数的用法讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
收藏 0 赞 0 分享
查看更多