欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

无限级分类注意

程序员文章站 2022-06-24 13:29:55
无限级分类主要救赎采用递归算法和特殊的数据表设计实现的 我的代码 老师的代码 明显不同,我设计的无限级是使用array进行嵌套,那么前台的显示就有很大的问题了, 嵌套几层相应的显示就要几层判断加循环,然而老师的使用的是二维array,通过level 来判断层级,顺序由于持续深入不变,同时在递归之前先 ......

无限级分类主要救赎采用递归算法和特殊的数据表设计实现的

我的代码

 1 /**
 2      * 获取顺序的菜单信息
 3      * 使用递归方法
 4      */
 5     public function getHierarchicalMenus($pid , $condition=array() , $cid = 0){
 6         $data = array();
 7         if (!isset($condition['status'])){
 8             $condition['status'] = array('neq' , -1);
 9         }
10         $condition['parentid'] = $pid;
11         $menus = $this->_db->where($condition)->order("listorder desc")->select();
12         if ($menus){
13             foreach ($menus as $v){
14                 $res = $this->getHierarchicalMenus($v['menu_id'] ,$condition ,$cid+1);
15                 if ($res){
16                     $v['child'] = $res;
17                     $v['cid'] = $cid;
18                 }else{
19                     $v['child'] = 0;
20                 }
21                 $v['cid'] = $cid;
22                 $data[] = $v;
23             }
24         }
25         return $data;
26     }

老师的代码

 1 public function getTree()
 2     {
 3         $data = $this->select();
 4         return $this->_reSort($data);
 5     }
 6     private function _reSort($data, $parent_id=0, $level=0, $isClear=TRUE)
 7     {
 8         static $ret = array();
 9         if($isClear)
10             $ret = array();
11         foreach ($data as $k => $v)
12         {
13             if($v['parent_id'] == $parent_id)
14             {
15                 $v['level'] = $level;
16                 $ret[] = $v;
17                 $this->_reSort($data, $v['id'], $level+1, FALSE);
18             }
19         }
20         return $ret;
21     }

明显不同,我设计的无限级是使用array进行嵌套,那么前台的显示就有很大的问题了,

嵌套几层相应的显示就要几层判断加循环,然而老师的使用的是二维array,通过level

来判断层级,顺序由于持续深入不变,同时在递归之前先将全部数据先记录下来,减少

数据库操作次数,提高数据库并发操作。