无限级分类总结

发布时间:2020-07-20 12:38:07 作者:与君同悦
来源:网络 阅读:354
<?php 
//无限级分类
$arr = array(
array('id'=>1,'name'=>'HeNan','parent_id'=>0),
array('id'=>2,'name'=>'nanyang','parent_id'=>1),
array('id'=>3,'name'=>'tanghe','parent_id'=>2),
array('id'=>4,'name'=>'HuBei','parent_id'=>0),
array('id'=>5,'name'=>'wuhan','parent_id'=>4),
array('id'=>6,'name'=>'FuJian','parent_id'=>0),
array('id'=>7,'name'=>'xiamen','parent_id'=>6),
array('id'=>8,'name'=>'huangshi','parent_id'=>5)
);


//递归法找指定栏目的子孙树
function subtree($data,$id=0,$lev=1){
    $arr = array();
    foreach($data as $v){
        if($v['parent_id']==$id){
            $v['lev'] = $lev;
            $arr[] = $v;
            $cid = $v['id'];
            $arr = array_merge($arr,subtree($data,$cid,$lev+1));
        }
    }
    return $arr;
}


//递归法找指定栏目的家谱树
function partree($data,$id=0){
    $arr = array();
    foreach($data as $v){
        if($v['id'] == $id){
            $arr[] = $v;
            $cid = $v['parent_id'];
            $arr = array_merge(partree($data,$cid),$arr);
        }
    }
    return $arr;
}

//迭代法查找指定栏目的家谱树
function fpartree($data,$id=0){
    $arr = array();
    while($id !== 0 ){
        foreach($data as $v){
            if($v['id'] == $id){
                $arr[] = $v;
                $id = $v['parent_id'];
                break;
            }
        }
    }
    return array_reverse($arr);
}


//排序输出
$subtree = subtree($arr,0);
foreach($subtree as $v){
    echo str_repeat('&nbsp&nbsp',$v['lev']).$v['name'].'<br />';
}

?>


推荐阅读:
  1. php下利用递归实现无限级分类
  2. 使用数组实现PHP无限级分类

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

分类 无限级 无限级分类

上一篇:trunk中继链路,以太网通道

下一篇:Screen position out of view fr

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》