0

0

php数据整理中如何按父子id生成嵌套数组_php递归生成嵌套结构与层级深度控制

絕刀狂花

絕刀狂花

发布时间:2025-11-27 17:07:11

|

846人浏览过

|

来源于php中文网

原创

答案:通过递归将扁平数组按parent_id构建成嵌套树形结构,可采用基础递归、引用优化、深度限制和排序支持四种方法。1、建立id索引后递归挂载子节点;2、利用引用映射表提升性能;3、添加depth参数防栈溢出;4、每层递归内对children按sort字段排序,确保有序输出。

php数据整理中如何按父子id生成嵌套数组_php递归生成嵌套结构与层级深度控制

如果您在处理PHP中的分类数据时,需要根据父ID(parent_id)将扁平数组转换为具有层级结构的嵌套数组,可以通过递归方式实现父子关系的自动关联。以下是几种有效的实现方法:

一、基础递归构建嵌套数组

该方法通过递归遍历原始数据,查找每个元素的子节点并将其挂载到对应父节点下,适用于无限层级的树形结构生成。

1、准备一个以id为键名的索引数组,便于快速查找节点。

2、遍历所有数据项,将每一项添加到其父ID对应的子数组中。

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

3、使用递归函数从根节点(parent_id = 0 或 null)开始逐层构建树状结构。

确保原始数据中存在 id 和 parent_id 字段,并且根节点的 parent_id 值为 0 或 null

二、使用引用传递优化性能

利用PHP的引用机制避免重复遍历,提高构建效率,特别适合数据量较大的场景。

1、创建一个空数组用于存储所有节点的引用,键名为节点ID。

2、循环原始数据,为每个节点初始化 children 数组,并通过引用存入映射表。

3、若当前节点有父节点,则将其加入父节点的 children 中。

4、收集所有 parent_id 为 0 或不存在于数据中的节点作为根节点返回。

阿里妈妈·创意中心
阿里妈妈·创意中心

阿里妈妈营销创意中心

下载

此方法时间复杂度接近 O(n),比纯递归更高效

三、控制最大层级深度防止无限递归

在实际应用中,可能需要限制生成树的最大层级,避免因数据异常导致溢出或页面加载过慢。

1、在递归函数中增加 depth 参数记录当前层级。

2、每次递归调用时判断 depth 是否已达到预设上限。

3、若超过最大深度,则停止继续向下查找子节点。

建议设置默认最大深度为 10 层以内,可根据业务需求调整

四、支持排序字段的有序嵌套结构生成

某些情况下要求子节点按照指定顺序排列(如 sort 字段),需在构建过程中进行排序处理。

1、在每个节点的 children 数组生成后,使用 usort 对其进行排序。

2、排序规则依据数据中的 order 或 sort 字段升序或降序排列。

3、确保递归返回前已完成子节点排序。

注意:排序操作应在每层递归内部完成,以保证各级别均有序

相关专题

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

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

2409

2023.09.01

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

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

1555

2023.10.11

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

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

1453

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数据库相关内容,可以阅读本专题下面的文章。

1414

2023.10.23

html怎么上传
html怎么上传

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

1234

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

Java 项目构建与依赖管理(Maven / Gradle)
Java 项目构建与依赖管理(Maven / Gradle)

本专题系统讲解 Java 项目构建与依赖管理的完整体系,重点覆盖 Maven 与 Gradle 的核心概念、项目生命周期、依赖冲突解决、多模块项目管理、构建加速与版本发布规范。通过真实项目结构示例,帮助学习者掌握 从零搭建、维护到发布 Java 工程的标准化流程,提升在实际团队开发中的工程能力与协作效率。

8

2026.01.12

热门下载

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

精品课程

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

共137课时 | 8.5万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 6.9万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.8万人学习

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

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