网站地图    收藏   

主页 > 后端 > ecshop教程 >

PHP中递归函数返回值使用介绍(ecshop无限分类) -

来源:自学PHP网    时间:2014-11-28 23:31 作者: 阅读:

[导读] 一款以ecshop无限分类为实例来介绍一下php中的递归函数返回值的问题介绍,在 ecshop 二次开发中做产品分类索引时,要根据分类 id 取得所...

PHP中递归函数返回值使用介绍(ecshop无限分类)

一款以ecshop无限分类为实例来介绍一下php中的递归函数返回值的问题介绍,在 ecshop 二次开发中做产品分类索引时,要根据分类 id 取得所属顶级分类 id,第一个反应就是用递归递出来,于是写了递归函数如下:

  1. function getCatTopId($cat_id
  2.     if ($cat_id
  3.     { 
  4.         $res = Array(); 
  5.         $sql = 'SELECT cat_id, parent_id' 
  6.              . ' FROM ' . $GLOBALS['ecs']->table('category')  
  7.              . ' WHERE cat_id = ' . $cat_id . ' AND is_show = 1'
  8.         $res = $GLOBALS['db']->getAll($sql); 
  9.         if ($res[0]['parent_id'] > 0) 
  10.         { 
  11.             getCatTopId($res[0]['parent_id']); 
  12.         } 
  13.         else 
  14.         { 
  15.             return $res[0]['cat_id']; 
  16.         } 
  17.     } 
  18.     else 
  19.     { 
  20.         return 1; 
  21.     } 

一测试程序,没有得到返回值?检查了很久都没有发现错误,看来脑壳断路了,今天问水神(一好心网友)时,他帮我解答出来了,修改如下:

  1. function getCatTopId($cat_id
  2.     if ($cat_id
  3.     { 
  4.         $res = Array(); 
  5.         $sql = 'SELECT cat_id, parent_id' 
  6.              . ' FROM ' . $GLOBALS['ecs']->table('category')  
  7.              . ' WHERE cat_id = ' . $cat_id . ' AND is_show = 1'
  8.         $res = $GLOBALS['db']->getAll($sql); 
  9.         if ($res[0]['parent_id'] > 0) 
  10.         { 
  11.             return getCatTopId($res[0]['parent_id']); // 修改处,多写个 return ,让函数返回值 
  12.         } 
  13.         else 
  14.         { 
  15.             return $res[0]['cat_id']; 
  16.         }    } 
  17.     else 
  18.     { 
  19.         return 1; 
  20.     } 

函数写在内部,就算返回了,也只是返回到内部的那个函数的位置,所以外面还有一层主函数,必须再 return 一下

自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习

京ICP备14009008号-1@版权所有www.zixuephp.com

网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com

添加评论