设为首页 收藏本站
查看: 737|回复: 0

[经验分享] PHP无限级分类实现(递归+非递归)

[复制链接]

尚未签到

发表于 2018-12-14 09:41:17 | 显示全部楼层 |阅读模式
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),
  
);
  

  
/*======================非递归实现========================*/
  
$tree = array();
  
//第一步,将分类id作为数组key,并创建children单元
  
foreach($categories as $category){
  
    $tree[$category['id']] = $category;
  
    $tree[$category['id']]['children'] = array();
  
}
  
//第二步,利用引用,将每个分类添加到父类children数组中,这样一次遍历即可形成树形结构。
  
foreach($tree as $key=>$item){
  
    if($item['pid'] != 0){
  
        $tree[$item['pid']]['children'][] = &$tree[$key];//注意:此处必须传引用否则结果不对
  
        if($tree[$key]['children'] == null){
  
            unset($tree[$key]['children']); //如果children为空,则删除该children元素(可选)
  
        }
  
    }
  
}
  
////第三步,删除无用的非根节点数据
  
foreach($tree as $key=>$category){
  
    if($category['pid'] != 0){
  
        unset($tree[$key]);
  
    }
  
}
  

  
print_r($tree);
  

  
/*======================递归实现========================*/
  
$tree = $categories;
  
function get_attr($a,$pid){
  
    $tree = array();                                //每次都声明一个新数组用来放子元素
  
    foreach($a as $v){
  
        if($v['pid'] == $pid){                      //匹配子记录
  
            $v['children'] = get_attr($a,$v['id']); //递归获取子记录
  
            if($v['children'] == null){
  
                unset($v['children']);             //如果子元素为空则unset()进行删除,说明已经到该分支的最后一个元素了(可选)
  
            }
  
            $tree[] = $v;                           //将记录存入新数组
  
        }
  
    }
  
    return $tree;                                  //返回新数组
  
}
  
print_r(get_attr($tree,0));



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-651191-1-1.html 上篇帖子: CentOS安装PHP5.6 下篇帖子: php composer.phar install 报错
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表