php 无限菜单,PHP写无限分类菜单

这个博客主要介绍了两个函数,find_child用于获取指定id的子节点数组,而get_tree则递归调用find_child来构建一个多维数组,包含指定根节点的所有子孙节点。这两个函数对于处理树形结构数据非常有用,例如组织结构、文件系统等场景。
摘要由CSDN通过智能技术生成

/**

* find_child,对于数组$arr,给定一个id,获取其子节点构成的一维数组

* @param $arr array 要遍历的数组

* @param $id int 该条记录的id,默认值为0

* @return array 返回$id记录对应的子节点数组

*/

function find_child($arr,$id=0){

$child = array();

foreach ($arr as $v) {

if($v[‘pid’] == $id){

$child[] = $v;

}

}

return $child;

}

/**

* get_tree,对于数组$arr,给定一个根,获取其子孙节点构成的多维数组

* @param $arr array 要遍历的数组

* @param $root_id int 根节点 id,默认为0

* @return array 返回$root_id节点对应的子孙节点构成的多维数组

*/

function get_tree($arr,$root_id=0){

$child = find_child($arr,$root_id);

if(empty($child)){

return null;

}

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

$current_tree = get_tree($arr,$v[‘id’]);

if ($current_tree != null) {

$child[$k][‘child’] = $current_tree;

}

}

return $child;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值