php数组如何转树状结构

php数组转树状结构的方法:1、创建一个PHP示例文件;2、构造一个函数,语法为“function buildTree(array $elements, $parentId = 0)”参数1是待转换的数组,参数2则是指定的根节点;3、函数内定义$branch空数组用于存储树状结构并进行遍历;4、遍历后将修改后的元素添加到$branch数组中,返回树状结构数组$branch即可。

本教程操作系统:Windows10系统、php8.1.3版本、Dell G3电脑。

将 PHP 数组转换为树状结构,可以通过递归方法实现。

下面是一个 PHP 函数示例:

1

2

3

4

5

6

7

8

9

10

11

12

13

function buildTree(array $elements, $parentId = 0) {

$branch = array();

foreach ($elements as $element) {

if ($element[parent_id] == $parentId) {

$children = buildTree($elements, $element[id]);

if ($children) {

$element[children] = $children;

}

$branch[] = $element;

}

}

return $branch;

}

登录后复制

在该函数中,参数 $elements 是待转换的数组,$parentId 则是指定的根节点(默认为 0)。函数首先定义一个名为 $branch 的空数组用于存储树状结构并进行遍历。

在每次循环内,函数会检查当前元素是否具有指定父 ID,如果是,则说明它是当前节点的子节点。然后调用自身的 buildTree() 函数来添加子节点,并将子节点分配给 $children 变量。函数继续判断 $children 是否为空,如果不是,将子节点赋值给当前元素的 children 键。最后,函数将修改后的元素添加到 $branch 数组中。

当所有元素处理完毕后,函数将返回树状结构数组 $branch。

假设我们有如下数据:

1

2

3

4

5

6

7

$elements = [

[id => 1, name => Parent 1, parent_id => 0],

[id => 2, name => Child 1, parent_id => 1],

[id => 3, name => Grandchild 1, parent_id => 2],

[id => 4, name => Grandchild 2, parent_id => 2],

[id => 5, name => Parent 2, parent_id => 0],

];

登录后复制

可以调用该函数生成树状结构。

以上就是php数组如何转树状结构的详细内容,更多请关注php中文网其它相关文章!

TG交流群(点击进入)----付费帮助搭建---修复---二开,以及发布求资源.
QQ交流群 922260178
© 版权声明
THE END
喜欢就支持一下吧
点赞1.7W+ 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容