
本教程详细介绍了如何在php中将复杂的树状数组结构(包含嵌套的`children`元素)高效地扁平化为一个简单的、按`id`排序的列表数组。通过递归函数遍历树的每个节点,提取其核心数据并处理`parent_id`,最终生成一个易于处理的扁平化数据集,适用于数据存储、展示或进一步处理。
在PHP开发中,我们经常会遇到将层级数据(如菜单、分类、组织结构等)表示为树状数组的需求。这种结构直观地展现了数据之间的父子关系。然而,在某些场景下,例如将数据存储到数据库、进行全局搜索或以列表形式展示所有项时,我们需要将这种树状结构“扁平化”为一个简单的、一维的数组列表。本文将详细讲解如何通过递归方法实现这一转换。
首先,我们来看一个典型的树状数组结构和它对应的扁平化数组结构。
原始树状数组示例: 一个包含id、name和children(子节点数组)的树状结构。顶级节点通常没有parent_id字段,或其parent_id为0或null。
$tree = [
[
"id" => 1,
"name" => "id1",
"children" => [
[
"id" => 2,
"parent_id" => 1,
"name" => "id2",
"children" => [
["id" => 5, "parent_id" => 2, "name" => "id5"]
]
],
[
"id" => 3,
"parent_id" => 1,
"name" => "id3",
"children" => [
["id" => 6, "parent_id" => 3, "name" => "id6"],
["id" => 8, "parent_id" => 3, "name" => "id8"]
]
]
]
],
[
"id" => 4,
"name" => "id4",
"children" => [
[
"id" => 9,
"parent_id" => 4,
"name" => "id9",
"children" => [
["id" => 10, "parent_id" => 9, "name" => "id10"]
]
]
]
],
["id" => 7, "name" => "id7", "children" => []]
];目标扁平化数组示例: 一个简单的数组列表,每个元素都是一个节点,包含id、parent_id和name,并且通常按id排序。
$array = [
['id'=> 1, 'parent_id' => 0, 'name' => 'id1'],
['id' => 2, 'parent_id' => 1, 'name'=> 'id2'],
['id' => 3, 'parent_id' => 1, 'name'=> 'id3'],
['id' => 4, 'parent_id' => 0, 'name'=> 'id4'],
['id' => 5,'parent_id' => 2, 'name'=> 'id5'],
['id' => 6, 'parent_id' => 3, 'name'=> 'id6'],
['id' => 7, 'parent_id' => 0, 'name'=> 'id7'],
['id' => 8, 'parent_id' => 3, 'name'=> 'id8'],
['id' => 9, 'parent_id' => 4, 'name'=> 'id9'],
['id' => 10, 'parent_id' => 9, 'name'=> 'id10'],
];注意,在扁平化数组中,即使是顶级节点,也需要明确指定parent_id(通常为0)。
将树状结构扁平化的最有效方法是使用递归。基本思路如下:
立即学习“PHP免费学习笔记(深入)”;
我们将通过两个函数来实现扁平化:一个递归辅助函数 flattenTree,和一个主函数 flatTree,负责初始化和最终排序。
<?php
/**
* 递归辅助函数:遍历树结构并收集扁平化节点
*
* @param array $nodes 当前层级的节点数组
* @param array $result 引用传递的结果数组,用于收集所有扁平化节点
* @return array 返回收集了所有扁平化节点的结果数组
*/
function flattenTree(array $nodes, array &$result = []): array
{
foreach ($nodes as $node) {
// 复制当前节点数据,并移除 'children' 键,因为扁平化后不再需要
$currentNode = $node;
unset($currentNode['children']);
// 如果当前节点没有 'parent_id' 字段(通常是根节点),则默认设置为 0
if (!isset($currentNode['parent_id'])) {
$currentNode['parent_id'] = 0;
}
// 将处理后的当前节点添加到结果数组
$result[] = $currentNode;
// 如果当前节点有子节点,则递归调用自身处理子节点
if (isset($node['children']) && is_array($node['children']) && !empty($node['children'])) {
flattenTree($node['children'], $result);
}
}
return $result;
}
/**
* 主函数:将树状数组扁平化为列表并按ID排序
*
* @param array $tree 待扁平化的树状数组
* @return array 扁平化并排序后的数组列表
*/
function flatTree(array $tree): array
{
$flatResult = [];
// 调用递归辅助函数进行扁平化
flattenTree($tree, $flatResult);
// 根据 'id' 字段对扁平化后的数组进行排序
usort($flatResult, static function (array $node1, array $node2) {
return ($node1['id'] < $node2['id']) ? -1 : 1;
});
// 重置数组键值,确保其为从0开始的连续整数
return array_values($flatResult);
}
// 示例树状数组
$tree = [
[
"id" => 1,
"name" => "id1",
"children" => [
[
"id" => 2,
"parent_id" => 1,
"name" => "id2",
"children" => [
["id" => 5, "parent_id" => 2, "name" => "id5"]
]
],
[
"id" => 3,
"parent_id" => 1,
"name" => "id3",
"children" => [
["id" => 6, "parent_id" => 3, "name" => "id6"],
["id" => 8, "parent_id" => 3, "name" => "id8"]
]
]
]
],
[
"id" => 4,
"name" => "id4",
"children" => [
[
"id" => 9,
"parent_id" => 4,
"name" => "id9",
"children" => [
["id" => 10, "parent_id" => 9, "name" => "id10"]
]
]
]
],
["id" => 7, "name" => "id7", "children" => []]
];
// 执行扁平化操作
$array = flatTree($tree);
// 打印结果
print_r($array);
?>以上就是PHP中将树状数组结构扁平化为列表的教程的详细内容,更多请关注php中文网其它相关文章!
PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号