php遍历不定维数组,不递归如何遍历多维数组(维数不定)

现有数组

$tree = array (array ('ID' => 1,'PARENT' => 0,'NAME' => '祖父','CHILD' => array (array ('ID' => 3,'PARENT' => 1,'NAME' => '叔伯' ),array ('ID' => 4,'PARENT' => 1,'NAME' => '父亲','CHILD' => array (array ('ID' => 5,'PARENT' => 4,'NAME' => '儿子' ) ) ) ) ),array ('ID' => 2,'PARENT' => 0,'NAME' => '祖母' ) );

欲达到效果的HTML代码

祖父叔伯

父亲儿子

祖母

不知道多维数组的具体维数,根据数据库得到的信息获得。

不使用递归,能实现这个效果吗

回复讨论(解决方案)

你是递归来的,当然应该递归去$tree = array ( array ( 'ID' => 1, 'PARENT' => 0, 'NAME' => '祖父', 'CHILD' => array ( array ( 'ID' => 3, 'PARENT' => 1, 'NAME' => '叔伯' ), array ( 'ID' => 4, 'PARENT' => 1, 'NAME' => '父亲', 'CHILD' => array ( array ( 'ID' => 5, 'PARENT' => 4, 'NAME' => '儿子' ) ) ) ) ), array ( 'ID' => 2, 'PARENT' => 0, 'NAME' => '祖母' ) );function 递归($ar, $deep=0) { echo str_repeat("\t", $deep) . "\n"; foreach($ar as $item) { echo str_repeat("\t", $deep + 1) . "

$item[NAME]"; if(isset($item['CHILD'])) { echo "\n"; 递归($item['CHILD'], $deep+2); } echo "\n"; } echo str_repeat("\t", $deep) . "\n";}递归($tree);

你是递归来的,当然应该递归去$tree = array ( array ( 'ID' => 1, 'PARENT' => 0, 'NAME' => '祖父', 'CHILD' => array ( array ( 'ID' => 3, 'PARENT' => 1, 'NAME' => '叔伯' ), array ( 'ID' => 4, 'PARENT' => 1, 'NAME' => '父亲', 'CHILD' => array ( array ( 'ID' => 5, 'PARENT' => 4, 'NAME' => '儿子' ) ) ) ) ), array ( 'ID' => 2, 'PARENT' => 0, 'NAME' => '祖母' ) );function 递归($ar, $deep=0) { echo str_repeat("\t", $deep) . "\n"; foreach($ar as $item) { echo str_repeat("\t", $deep + 1) . "

$item[NAME]"; if(isset($item['CHILD'])) { echo "\n"; 递归($item['CHILD'], $deep+2); } echo "\n"; } echo str_repeat("\t", $deep) . "\n";}递归($tree);

我这个不是通过递归获得的,是用你写的一篇文章中的方法 http://bbs.csdn.net/topics/370094009

数据原型为

$data = array( array('ID'=>1, 'PARENT'=>0, 'NAME'=>'祖父'), array('ID'=>2, 'PARENT'=>1, 'NAME'=>'父亲'), array('ID'=>3, 'PARENT'=>1, 'NAME'=>'叔伯'), array('ID'=>4, 'PARENT'=>2, 'NAME'=>'自己'), array('ID'=>5, 'PARENT'=>4, 'NAME'=>'儿子'),);

不递归能演变成我欲达到的HTML代码的效果吗

祖父 叔伯

父亲 儿子

祖母

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值