PHP无限分类的最好的方法

PHP无限分类的最好的方法每次写网页菜单和网页树形分类时 总是犹豫怎么写简单 怎么写更好 自己能想到的方法 99 的情况下 都不是最好的解决方案 我经常这样提醒自己 因为大神非常多 我可以自信 但不能自以为是 结合很多网友的方案 记作备忘录 都是几种比较简洁的方

欢迎大家来到IT世界,在知识的湖畔探索吧!

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

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

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

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

方案一:

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; }

欢迎大家来到IT世界,在知识的湖畔探索吧!

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

方案二:

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

欢迎大家来到IT世界,在知识的湖畔探索吧!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; }

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

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

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://itzsg.com/89567.html

(0)
上一篇 2024年 11月 21日 上午7:05
下一篇 2024年 11月 21日 上午7:23

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们YX

mu99908888

在线咨询: 微信交谈

邮件:itzsgw@126.com

工作时间:时刻准备着!

关注微信