递归并不一定非得是“自己调用自己的function”
浏览:3181次 出处信息
-_-居然忘掉鸟while、for这么好的哥们。。。昨日晚上于家中折腾CrumbNavigation,即所谓面包屑导航。。一直在为递归纠结。。哎。。香烟过后,恍然大悟啊。。T.T…这个教训不能忘。
- $db = new mysqli('localhost','root','******','test',3306);
- $db->query("set names utf8");
- $cid = isset($_GET['cid']) ? intval($_GET['cid']) : 0;
- $data = getCrumbNavigation($cid);
- echo "OXOXOXOX鸟站 >> ".implode(' >> ',$data);echo '
'; - $query = $db->query("select * from cate where pid = {$cid} order by sort");
- if(@$query->num_rows > 0) {
- $cate = array();
- while($row=$query->fetch_assoc()) {
- $cate[]=''.$row['id'].'">'.$row['name'].'';
- }
- echo '当前分类的下级分类有
'; - echo implode(' ',$cate);
- } else {
- echo '@.@木有了.';
- }
- function getCrumbNavigation($category_id) {
- $crumbNavigation = array();
- global $db;
- $old_id = $category_id;
- while(true) {
- $res = $db->query("select * from cate where id = {$category_id}");
- if($res) {
- $cate = $res->fetch_assoc();
- $crumbNavigation[] = $cate['id']!=$old_id ? ''.$cate['id'].'">'.$cate['name'].'':$cate['name'];
- if($cate['pid'] != 0) {
- $category_id = $cate['pid'];
- } else {
- break;
- }
- } else {
- break;
- }
- }
- krsort($crumbNavigation);
- return $crumbNavigation;
- }
效果如下(
建议继续学习:
- 120个优秀的水平导航设计 (阅读:73831)
- PHP与递归Recursion (阅读:8241)
- 网站导航设计的6大分类 (阅读:7865)
- 循环、迭代、遍历和递归 (阅读:4449)
- 我们来做一个会呼吸的菜单吧!! (阅读:3260)
- 小心递归次数限制 (阅读:3078)
- PHP正则之递归匹配 (阅读:2717)
- 倒置字符串中的单词 (阅读:2469)
- 无限递归导致 Segmentation fault (阅读:2424)
- 实现一个更精简的Tab (阅读:2407)
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
扫一扫订阅我的微信号:IT技术博客大学习
<< 前一篇:web socket 心跳包的实现方案
后一篇:令人纠结的php几率算法问题 >>
文章信息
- 作者:cevin 来源: 司徒楠,一个PHP程序员
- 标签: 导航 递归 面包屑
- 发布时间:2010-06-05 11:37:45
建议继续学习
近3天十大热文
- [56] Oracle MTS模式下 进程地址与会话信
- [56] IOS安全–浅谈关于IOS加固的几种方法
- [55] 如何拿下简短的域名
- [54] 图书馆的世界纪录
- [53] Go Reflect 性能
- [53] android 开发入门
- [50] 读书笔记-壹百度:百度十年千倍的29条法则
- [49] 【社会化设计】自我(self)部分――欢迎区
- [38] 程序员技术练级攻略
- [33] 视觉调整-设计师 vs. 逻辑