IT技术博客大学习 共学习 共进步

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

司徒楠,一个PHP程序员 2010-06-05 11:37:45 浏览 4,161 次

-_-居然忘掉鸟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个优秀的水平导航设计 (阅读 75,440)
  2. 网站导航设计的6大分类 (阅读 9,140)
  3. PHP与递归Recursion (阅读 9,120)
  4. 循环、迭代、遍历和递归 (阅读 5,421)
  5. 我们来做一个会呼吸的菜单吧!! (阅读 4,221)
  6. 小心递归次数限制 (阅读 3,940)
  7. 与众不同易,精益求精难 — QQ导航改版设计心得 (阅读 3,881)
  8. 用面包屑来简化多层的tabs (阅读 3,601)
  9. PHP正则之递归匹配 (阅读 3,601)
  10. 网站导航设计模式指南 (阅读 3,501)