技术头条 - 一个快速在微博传播文章的方式     搜索本站
您现在的位置首页 --> 算法 --> 递归并不一定非得是“自己调用自己的function”

递归并不一定非得是“自己调用自己的function”

浏览:3166次  出处信息

-_-居然忘掉鸟while、for这么好的哥们。。。昨日晚上于家中折腾CrumbNavigation,即所谓面包屑导航。。一直在为递归纠结。。哎。。香烟过后,恍然大悟啊。。T.T…这个教训不能忘。

  1. $db = new mysqli('localhost','root','******','test',3306);
  2. $db->query("set names utf8");
  3. $cid = isset($_GET['cid']) ? intval($_GET['cid']) : 0;
  4. $data = getCrumbNavigation($cid);
  5. echo "OXOXOXOX鸟站 >> ".implode(' >> ',$data);echo '
    ';
  6. $query = $db->query("select * from cate where pid = {$cid} order by sort");
  7. if(@$query->num_rows > 0) {
  8.     $cate = array();
  9.     while($row=$query->fetch_assoc()) {
  10.         $cate[]=''.$row['id'].'">'.$row['name'].'';
  11.     }
  12.     echo '当前分类的下级分类有
    ';
  13.     echo implode('  ',$cate);
  14. } else {
  15.     echo '@.@木有了.';
  16. }
  17. function getCrumbNavigation($category_id) {
  18.     $crumbNavigation = array();
  19.     global $db;
  20.     $old_id = $category_id;
  21.     while(true) {
  22.         $res = $db->query("select * from cate where id = {$category_id}");
  23.         if($res) {
  24.             $cate = $res->fetch_assoc();
  25.             $crumbNavigation[] = $cate['id']!=$old_id ? ''.$cate['id'].'">'.$cate['name'].'':$cate['name'];
  26.             if($cate['pid'] != 0) {
  27.                 $category_id = $cate['pid'];
  28.             } else {
  29.                 break;
  30.             }
  31.         } else {
  32.             break;
  33.         }
  34.     }
  35.     krsort($crumbNavigation);
  36.     return $crumbNavigation;
  37. }

效果如下(

建议继续学习:

  1. 120个优秀的水平导航设计    (阅读:73808)
  2. PHP与递归Recursion    (阅读:8229)
  3. 网站导航设计的6大分类    (阅读:7837)
  4. 循环、迭代、遍历和递归    (阅读:4432)
  5. 我们来做一个会呼吸的菜单吧!!    (阅读:3244)
  6. 小心递归次数限制    (阅读:3069)
  7. PHP正则之递归匹配    (阅读:2703)
  8. 倒置字符串中的单词    (阅读:2462)
  9. 无限递归导致 Segmentation fault    (阅读:2420)
  10. 实现一个更精简的Tab    (阅读:2392)
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
© 2009 - 2024 by blogread.cn 微博:@IT技术博客大学习

京ICP备15002552号-1