🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
1. 第一种 ``` //无极限分类--递归 public function getTree($array, $pid =0, $level = 0){ //声明静态数组,避免递归调用时,多次声明导致数组覆盖 static $list = []; foreach ($array as $key => $value){ //第一次遍历,找到父节点为根节点的节点 也就是pid=0的节点 if ($value['pid'] == $pid){ //父节点为根节点的节点,级别为0,也就是第一级 $value['level'] = $level; //把数组放到list中 $list[] = $value; //把这个节点从数组中移除,减少后续递归消耗 unset($array[$key]); //开始递归,查找父ID为该节点ID的节点,级别则为原级别+1 $this->getTree($array, $value['id'], $level+1); } } return $list; } ``` 2. 第二种 ```php if (!function_exists('get_cate_list')) { //递归函数 实现无限级分类列表 function get_cate_list($list,$pid=0,$level=0) { static $tree = array(); foreach($list as $row) { if($row['pid']==$pid) { $row['level'] = $level; $tree[] = $row; get_cate_list($list, $row['id'], $level + 1); } } return $tree; } } ``` 3. 第三种 ```php if(!function_exists('get_tree_list')){ //引用方式实现 父子级树状结构 function get_tree_list($list){ //将每条数据中的id值作为其下标 $temp = []; foreach($list as $v){ $v['son'] = []; $temp[$v['id']] = $v; } //获取分类树 foreach($temp as $k=>$v){ $temp[$v['pid']]['son'][] = &$temp[$v['id']]; } return isset($temp[0]['son']) ? $temp[0]['son'] : []; } } ``` ## 获取父类id下的所有子类id和孙子类id ```php //获取用户的所有下级ID function get_downline($members,$mid,$level=0){ $arr=array(); foreach ($data as $key => $v) { if($v['pid']==$mid){ //pid为0的是顶级分类 $v['level'] = $level+1; $arr[]=$v; $arr = array_merge($arr,get_downline($data,$v['id'],$level+1)); } } return $arr; } ```