无限级分类注意
2018-06-22 05:35:07来源:未知 阅读 ()
无限级分类主要救赎采用递归算法和特殊的数据表设计实现的
我的代码
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
来判断层级,顺序由于持续深入不变,同时在递归之前先将全部数据先记录下来,减少
数据库操作次数,提高数据库并发操作。
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- php连接mssql的一些相关经验及注意事项 2019-10-17
- php使用Smarty时的注意事项及访问变量方式 2019-08-23
- 错误处理 2019-05-18
- 软件架构、IP、端口号、域名、网站分类 2019-05-17
- PHP在无限分类时注意的一些问题(不保证代码完全正确哦) 2019-05-13
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash