龙空技术网

PHP无限分类的最好的方法

臻鑫 353

前言:

而今看官们对“php分类信息系统”大致比较关切,大家都需要剖析一些“php分类信息系统”的相关内容。那么小编在网摘上汇集了一些有关“php分类信息系统””的相关知识,希望兄弟们能喜欢,小伙伴们一起来了解一下吧!

每次写网页菜单和网页树形分类时,总是犹豫怎么写简单,怎么写更好。

“自己能想到的方法,99%的情况下,都不是最好的解决方案。”我经常这样提醒自己,因为大神非常多,我可以自信,但不能自以为是。

结合很多网友的方案,记作备忘录(都是几种比较简洁的方案)。

备注:无限分类三个必备参数 id(分类id),pid(分类的父id),name(分类名称)

方案一:

无限分类思路图

判断依据是:子类的父级id是否等于父级的id

function getTree($arr,$pid=0,$level=1){static $list = [];foreach ($arr as $key => $value) {if($value['pid'] == $pid){// 判断子类的父级id 是否等于 父级的id$value['level'] = $level;$list[] = $value;unset($arr[$key]); // 删除已排好的数据,减少循环次数getTree($arr,$value['id'],$level+1); // 递归函数}}return $list;}

点评:这种方法我一直以来用得最多,感觉简单,容易理解,分层明确。

方案二:

原生的数据库取值的方法,循环从数据库中获取记录(消耗相对较大)。

function getCate($pid = 0) {    //1.通过父级id获得子级list    $sql = "select * from cate where pid=".$pid;    $res = mysql_query($sql);    if($res)    {        while($row = mysql_fetch_assoc($res)){            $categories[] = $row;        }    }    //2.获取某级分类及子分类(无限tree) (重点)    if(0 < count($categories))    {        for($i = 0; $i < count($categories); $i++)        {            $categories[$i]['child'] = getCate($categories[$i]['id']);        }    }    return $categories;}//测试调用$cate = getCate(0);

点评:这种方法不建议用,虽然思路最直白,但对系统消耗较大。

方案三:

private function tree_data(&$list, $parent){    $tree = array();    foreach($list as $row) {        if($row['pid'] == $parent) {            $row['children'] = $this->tree_data($list, $row['id']);            $tree[] = $row;        }    }    return $tree;}

点评:短短数行代码,简单、简洁!漂亮!这种方案个人最喜欢!

当然,还有其他的思路,你可否分享出来呢?

标签: #php分类信息系统