首页 » 网站建设 » php归类技巧_PHP无限分类的最好的方法

php归类技巧_PHP无限分类的最好的方法

访客 2024-10-24 0

扫一扫用手机浏览

文章目录 [+]

“自己能想到的方法,99%的情形下,都不是最好的办理方案。
”我常常这样提醒自己,由于大神非常多,我可以自傲,但不能自以为是。

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

php归类技巧_PHP无限分类的最好的方法

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

php归类技巧_PHP无限分类的最好的方法
(图片来自网络侵删)

方案一:

无限分类思路图

判断依据是:子类的父级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;}

点评:短短数行代码,大略、简洁!
俊秀!
这种方案个人最喜好!

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

相关文章

微信第三方登录便捷与安全的完美融合

社交平台已成为人们日常生活中不可或缺的一部分。微信作为我国最受欢迎的社交软件之一,拥有庞大的用户群体。为了方便用户在不同平台间切换...

网站建设 2025-02-18 阅读0 评论0

广东高速代码表解码高速公路管理智慧

高速公路作为国家交通动脉,连接着城市与城市,承载着巨大的物流和人流。广东作为我国经济大省,高速公路网络密布,交通流量巨大。为了更好...

网站建设 2025-02-18 阅读0 评论0