php 递归tp前台遍历,thinkphp5.0无限递归操作

PHP无限极分类操作(递归)

初始数据:$arr = array(

array('id'=>1,'name'=>'电脑','pid'=>0),

array('id'=>2,'name'=>'手机','pid'=>0),

array('id'=>3,'name'=>'笔记本','pid'=>1),

array('id'=>4,'name'=>'台式机','pid'=>1),

array('id'=>5,'name'=>'智能机','pid'=>2),

array('id'=>6,'name'=>'功能机','pid'=>2),

array('id'=>7,'name'=>'超级本','pid'=>3),

array('id'=>8,'name'=>'游戏本','pid'=>3),

);

公共方法:(index.php)public function getTree($arr,$id){

$list =array();

foreach ($arr as $k=>$v){

if ($v['pid'] == $id){

$v['son'] = $this -> getTree($arr,$v['id']);

$list[] = $v;

}

}

return $list;

}

调用方法:use app\common\controller\Index as commonIndex;

public function test(){

//引入公用数据

$common = new commonIndex();

$arr = array(

array('id'=>1,'name'=>'电脑','pid'=>0),

array('id'=>2,'name'=>'手机','pid'=>0),

array('id'=>3,'name'=>'笔记本','pid'=>1),

array('id'=>4,'name'=>'台式机','pid'=>1),

array('id'=>5,'name'=>'智能机','pid'=>2),

array('id'=>6,'name'=>'功能机','pid'=>2),

array('id'=>7,'name'=>'超级本','pid'=>3),

array('id'=>8,'name'=>'游戏本','pid'=>3),

);

$array = $common -> getTree($arr,0);

echo '

';

dump($array);

}

返回的数据样式:array(2) {

[0] => array(4) {

["id"] => int(1)

["name"] => string(6) "电脑"

["pid"] => int(0)

["son"] => array(2) {

[0] => array(4) {

["id"] => int(3)

["name"] => string(9) "笔记本"

["pid"] => int(1)

["son"] => array(2) {

[0] => array(4) {

["id"] => int(7)

["name"] => string(9) "超级本"

["pid"] => int(3)

["son"] => array(0) {

}

}

[1] => array(4) {

["id"] => int(8)

["name"] => string(9) "游戏本"

["pid"] => int(3)

["son"] => array(0) {

}

}

}

}

[1] => array(4) {

["id"] => int(4)

["name"] => string(9) "台式机"

["pid"] => int(1)

["son"] => array(0) {

}

}

}

}

[1] => array(4) {

["id"] => int(2)

["name"] => string(6) "手机"

["pid"] => int(0)

["son"] => array(2) {

[0] => array(4) {

["id"] => int(5)

["name"] => string(9) "智能机"

["pid"] => int(2)

["son"] => array(0) {

}

}

[1] => array(4) {

["id"] => int(6)

["name"] => string(9) "功能机"

["pid"] => int(2)

["son"] => array(0) {

}

}

}

}

}

以上便是所有步骤流程,仁者见仁,智者见智,祝各位码农旗开得胜!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值