0

0

PHP递归构建树形结构数组:从扁平数据到嵌套层级

聖光之護

聖光之護

发布时间:2025-07-22 14:14:01

|

990人浏览过

|

来源于php中文网

原创

PHP递归构建树形结构数组:从扁平数据到嵌套层级

本教程详细讲解如何使用PHP递归函数将具有父子关系的扁平化数组转换为嵌套的树形结构。通过修正常见错误,演示了如何正确地在递归过程中将子元素封装到父元素的特定键(如'pages')下,从而高效地组织和展示层级数据。

1. 引言:从扁平数据到树形结构的需求

在web开发中,我们经常会遇到需要处理具有层级关系的数据,例如菜单导航、评论回复、组织架构或文件目录等。这类数据在数据库中通常以扁平化的形式存储,即每条记录包含一个id和指向其父级记录的parentid。然而,为了更好地在前端展示或进行逻辑处理,我们往往需要将这种扁平结构转换为嵌套的树形结构。递归是解决此类问题的强大工具

2. 核心概念:递归的运用

递归是一种函数调用自身的技术。在构建树形结构时,递归的核心思想是:

  1. 识别当前层级的元素:找到所有直接属于当前父级ID的元素。
  2. 为每个元素查找子元素:对当前层级的每个元素,将其自身的ID作为新的父级ID,递归调用函数以查找其下一级子元素。
  3. 构建层级关系:将找到的子元素作为当前元素的某个属性(例如pages)添加到当前元素中。

3. 数据结构:输入与期望输出

假设我们有以下扁平化的数组数据,其中每个元素包含id、parentid、route和title:

$indexes = [
    ['id' => 1, 'parentid' => 0, 'route' => 'root', 'title' => 'root'],
    ['id' => 2, 'parentid' => 1, 'route' => 'parent', 'title' => 'parent'],
    ['id' => 3, 'parentid' => 2, 'route' => 'child', 'title' => 'child']
];

我们期望通过处理,得到一个嵌套的树形结构,例如:

$index = [
    [
        'id' => 1,
        'parentid' => 0,
        'route' => 'root',
        'title' => 'root',
        'pages' => [
            [
                'id' => 2,
                'parentid' => 1,
                'route' => 'parent',
                'title' => 'parent',
                'pages' => [
                    [
                        'id' => 3,
                        'parentid' => 2,
                        'route' => 'child',
                        'title' => 'child'
                    ]
                ]
            ]
        ]
    ]
];

4. 递归函数的实现与解析

以下是用于构建树形结构的buildSubs函数,并对其关键部分进行解析:

立即学习PHP免费学习笔记(深入)”;

 1, 'parentid' => 0, 'route' => 'root', 'title' => 'root'],
    ['id' => 2, 'parentid' => 1, 'route' => 'parent', 'title' => 'parent'],
    ['id' => 3, 'parentid' => 2, 'route' => 'child', 'title' => 'child']
];

// 调用函数构建树形结构
// 为了获取完整的树,通常从根节点的parentId(例如0)开始
$tree = buildSubs($indexes, 0);

// 输出结果
echo "
";
var_dump($tree);
echo "
"; ?>

关键修正点:$elm['pages'] = $children;

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

下载

原始代码中可能存在的错误是使用了$elms['pages'] = $children;。这是一个常见的混淆点:

  • $elms:代表的是整个原始的扁平数组。如果你尝试向$elms添加pages键,你实际上是在修改原始数组的顶层结构,而不是当前正在处理的单个元素。
  • $elm:代表的是foreach循环中当前迭代到的单个元素。我们希望将子元素添加到这个特定的父元素内部,因此应该使用$elm['pages']。

5. 调用与结果展示

为了构建完整的树形结构,我们需要从根节点开始调用buildSubs函数。通常,根节点的parentid会被设置为一个特殊值,例如0或null。在我们的例子中,根节点的parentid是0。

$tree = buildSubs($indexes, 0);

运行上述代码,将得到如下的树形结构输出:

array(1) {
  [0]=>
  array(5) {
    ["id"]=>
    int(1)
    ["parentid"]=>
    int(0)
    ["route"]=>
    string(4) "root"
    ["title"]=>
    string(4) "root"
    ["pages"]=>
    array(1) {
      [0]=>
      array(5) {
        ["id"]=>
        int(2)
        ["parentid"]=>
        int(1)
        ["route"]=>
        string(6) "parent"
        ["title"]=>
        string(6) "parent"
        ["pages"]=>
        array(1) {
          [0]=>
          array(4) {
            ["id"]=>
            int(3)
            ["parentid"]=>
            int(2)
            ["route"]=>
            string(5) "child"
            ["title"]=>
            string(5) "child"
          }
        }
      }
    }
  }
}

6. 注意事项与最佳实践

  • 初始parentId的选择:确保你了解你的数据中根节点的parentid是什么,并用它来初始化你的递归调用。如果存在多个根节点(例如,parentid都是0),那么buildSubs函数将返回一个包含所有这些根节点的数组,每个根节点下都包含了其完整的子树。
  • 性能考量:对于非常庞大或深度极深的扁平数据集,纯粹的递归方法可能会导致性能问题(如栈溢出或效率低下)。在这种情况下,可以考虑以下优化:
    • 预处理数据:将扁平数组转换为以id为键的关联数组,这样在查找子元素时可以避免遍历整个数组,提高查找效率。
    • 迭代法:对于极大规模的数据,迭代法(例如使用队列或栈)可能比递归更有效率,因为它避免了函数调用的开销和栈深度限制。
    • 数据库查询优化:如果数据来自数据库,考虑在数据库层面进行部分层级查询,减少PHP的内存压力。
  • 数据完整性:确保你的扁平数据中id和parentid的对应关系是正确的,否则可能导致无限递归或结构不完整。
  • 键名约定:在本例中,我们使用pages作为子元素的键名。你可以根据实际需求将其命名为children、subItems等。

7. 总结

通过本教程,我们学习了如何使用PHP递归函数将扁平化的父子关系数据转换为嵌套的树形结构。掌握这种技术对于处理各种层级数据至关重要。正确理解递归的原理,特别是对循环变量和作用域的把握,是成功实现此类功能的关键。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2366

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1539

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1435

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

951

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1413

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1233

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1445

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1305

2023.11.13

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

78

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 3.5万人学习

Pandas 教程
Pandas 教程

共15课时 | 0.9万人学习

ASP 教程
ASP 教程

共34课时 | 3.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号