php html分类树,多维数组分类树 组合html树的问题?(递归)

这篇博客探讨了一个关于使用PHP处理数组并递归生成HTML树形结构的函数。作者遇到了输出错误的问题,并怀疑是递归逻辑出现了问题。博客中提供了完整的测试数据和代码,包括数据格式化、多维数组树形结构的创建以及HTML树的生成。通过分析和调试代码,可以发现并解决这个问题,帮助读者理解如何正确处理此类递归任务。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

数组结构是这样的:

edc8debfb185a8a78ac73d1ec37bc79d.png

然后组装成html结构的方法如下:

function creatHtmlTree($tree)

{

static $htmlTree;

$htmlTree .= '

  • ';

foreach ($tree as $key => $value) {

$htmlTree .= "

{$value['name']} Goes somewhere";

if (isset($value['childs']) && is_array($value['childs'])) {

$html = creatHtmlTree($value['childs']);

$htmlTree .= $html;

}

$htmlTree .= "

";

}

$htmlTree .= "

";

return $htmlTree;

}

但是实际上输出的结果是错误的:

3c7a98d60ac1eca8a002b0569a7253a0.png

自己猜想,一定是自己的递归逻辑有问题,但是实在是想不明白问题到底出在哪里。所以还请帮忙看下,那段递归代码有什么问题

另外贴出完整的测试代码:

$data[] =array('id'=>1,'parentid'=>0,'name'=>'中国');

$data[] =array('id'=>2,'parentid'=>0,'name'=>'美国');

$data[] =array('id'=>3,'parentid'=>0,'name'=>'韩国');

$data[] =array('id'=>4,'parentid'=>1,'name'=>'北京');

$data[] =array('id'=>5,'parentid'=>1,'name'=>'上海');

$data[] =array('id'=>6,'parentid'=>1,'name'=>'广西');

$data[] =array('id'=>7,'parentid'=>6,'name'=>'桂林');

$data[] =array('id'=>8,'parentid'=>6,'name'=>'南宁');

$data[] =array('id'=>9,'parentid'=>6,'name'=>'柳州');

$data[] =array('id'=>10,'parentid'=>2,'name'=>'纽约');

$data[] =array('id'=>11,'parentid'=>2,'name'=>'华盛顿');

$data[] =array('id'=>12,'parentid'=>3,'name'=>'首尔');

/**格式化数组输出**/

function p($arr)

{

echo "

";

echo '========================开始========================';

echo "";

if( $arr ){

print_r($arr);

} else {

echo '此值为空';

}

echo "";

echo '========================结束========================';

echo "

";

}

/**

* 多维数组树形结构

*/

function tree($data, $pid = 0)

{

// static $html = '';

// $html .= '

  • ';

$children = [];

// p($data);

foreach ($data as $key => $value) {

if ($value['parentid'] == $pid) {

// $html .= '

';

$children[] = $value;

}

}

if (empty($children)) {

return null;

}

foreach ($children as $key => $value) {

$chid = tree($data, $value['id']);

if ($chid != null) {

$children[$key]['childs'] = $chid;

}

}

// $html .= '

';

return $children;

}

function creatHtmlTree($tree)

{

static $htmlTree;

$htmlTree .= '

  • ';

foreach ($tree as $key => $value) {

$htmlTree .= "

{$value['name']} Goes somewhere";

if (isset($value['childs']) && is_array($value['childs'])) {

$html = creatHtmlTree($value['childs']);

$htmlTree .= $html;

}

$htmlTree .= "

";

}

$htmlTree .= "

";

return $htmlTree;

}

$tree = tree($data);

$htmlTree = creatHtmlTree($tree);

p($tree);

p($htmlTree);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值