简单的无限分类中递归子栏目

本文介绍了一种使用PHP实现的树状结构遍历方法,包括查找子栏目和获取子孙树的功能。通过递归函数实现了不同层级的数据展示,并通过实例演示了如何进行层次缩进显示。
.
<?php

/*
 * 找子栏目
 */

$area=array(
array('id'=>1,'name'=>'中国','parent'=>0),
array('id'=>2,'name'=>'广东','parent'=>1),
array('id'=>3,'name'=>'深圳','parent'=>2),
array('id'=>4,'name'=>'湖南','parent'=>1),
array('id'=>5,'name'=>'长沙','parent'=>4)	
);

function findson($arr,$id=0) {
	  $son=array();
	foreach ($arr as $value) {
		if ($value['parent']==$id) {
			$son[]=$value;
		}
	}
	return $son;
}

/*
 * 找子孙树
 * @param array 传入的数组
 * @param int  传入的id
 */

function substree($arr,$id=0,$level=1) {
	   static $grandson=array();
	
	foreach ($arr as $value) {
		if ($value['parent']==$id) {
			$value['level']=$level;
			$grandson[]=$value;
			substree($arr,$value['id'],$level+1);
		}
	}
	  return $grandson;
}

//var_dump( findson($area,1));
echo  "</br>";
//var_dump(substree($area,2));

/*
 * 为了让它显示缩进效果
 */
$tt=substree($area,0,1);

   foreach ($tt as $value) {
   	 echo str_repeat('  ', $value["level"]).$value["name"]."</br>";
   }
   
?>

转载于:https://my.oschina.net/u/998304/blog/350604

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值