PHP实现无限极分类图文教程
2015-01-24信息快讯网
本文从数据库设计,代码编写到效果图详细介绍了php实现无限极分类的全过程,图文并茂,是篇值得推荐的文章,小伙伴们拿走参考下吧
一般来说实现无限极分类都是使用递归或者迭代的方式,小伙伴们看下本文的实现方式吧。
1,数据库设计:
2,代码:
/** * @author koma * @todo PHP无限极分类 */ $cn = mysql_connect('localhost', 'root', '') or die(mysql_error()); mysql_select_db('t', $cn) or die(mysql_error()); mysql_query('set names utf8'); /** * 从顶层逐级向下获取子类 * @param number $pid * @param array $lists * @param number $deep * @return array */ function getLists($pid = 0, &$lists = array(), $deep = 1) { $sql = 'SELECT * FROM category WHERE pid='.$pid; $res = mysql_query($sql); while ( ($row = mysql_fetch_assoc($res)) !== FALSE ) { $row['catename'] = str_repeat(' ', $deep).'|---'.$row['catename']; $lists[] = $row; getLists($row['id'], $lists, ++$deep); //进入子类之前深度+1 --$deep; //从子类退出之后深度-1 } return $lists; } function displayLists($pid = 0, $selectid = 1) { $result = getLists($pid); $str = '<select>'; foreach ( $result as $item ) { $selected = ""; if ( $selectid == $item['id'] ) { $selected = 'selected'; } $str .= '<option '.$selected.'>'.$item['catename'].'</option>'; } return $str .= '</select>'; } /** * 从子类开始逐级向上获取其父类 * @param number $cid * @param array $category * @return array: */ function getCategory($cid, &$category = array()) { $sql = 'SELECT * FROM category WHERE id='.$cid.' LIMIT 1'; $result = mysql_query($sql); $row = mysql_fetch_assoc($result); if ( $row ) { $category[] = $row; getCategory($row['pid'], $category); } krsort($category); //逆序,达到从父类到子类的效果 return $category; } function displayCategory($cid) { $result = getCategory($cid); $str = ""; foreach ( $result as $item ) { $str .= '<a href="'.$item['id'].'">'.$item['catename'].'</a>>'; } return substr($str, 0, strlen($str) - 1); } echo displayLists(0, 3); echo displayCategory(13);
3,效果图:
是不是很简单呢,小伙伴们可以直接拿去用哈,不收版权费^_^
php+mysql实现无限分类实例详解
将FCKeditor导入PHP+SMARTY的实现方法
php实现redis数据库指定库号迁移的方法
php模拟登陆的实现方法分析
php获取四位字母和数字的随机数的实现方法
使用PHP Socket 编程模拟Http post和get请求
php获取指定日期之间的各个周和月的起止时间
Thinkphp搭建包括JS多语言的多语言项目实现方法
php使用str_replace实现输入框回车替换br的方法
php采用curl实现伪造IP来源的方法
php实现事件监听与触发的方法
PHP图片处理之使用imagecopyresampled函数实现图片缩放例子
php无限极分类递归排序实现方法