php实现无限级分类实现代码(递归方法)


Posted in PHP onJanuary 01, 2011

开始以为这样的功能似乎很难,之前也做过一个百科的东西,其中也涉及到了分类的功能,不过不是无限级的分类,而是简单的实现了固定的三级分类,当时是自己设计的,想在想起来实现方法太土了,其实三级分类也只是无限级分类的一种特殊情况而已嘛。经过一段时间考虑,已经有了一些眉目,到网上一查,原来这样的东西铺天盖地,呵呵。其实无限级下拉列表功能是很简单的,无非就是用一个递归算法就好啦。
首先要设计数据库,需要建一个表,里面存储分类信息,至少需要3个字段,第一个是主键(ID),第二个是父级分类ID(parentid),第三个是分类的名称(classname)。可能的一种效果是:
ID PARENTID CLASSNAME
1 0 一级分类A
2 0 一级分类B
3 1 二级分类A
4 1 二级分类B
主要思路:首先看第三行和第四行,父类ID(PARENTID)的值是1,表示属于id=1这个类的子类,而,一,二两行因为是一级分类,没有上级分类,所以父类ID(PARENTID)的值是0,表示初级分类,依次类推便实现了无限级分类。最终的效果是:
├一级分类A
├─┴二级分类A
├─┴二级分类B
├一级分类B
然后就是程序,这里以PHP作为描述语言,可以很方便的改成其他语言,因为原理相似,就是一个递归而已。

<?php 
$dbhost = "localhost"; // 数据库主机名 
$dbuser = "root"; // 数据库用户名 
$dbpd = "123456"; // 数据库密码 
$dbname = "test"; // 数据库名 
mysql_connect($dbhost,$dbuser,$dbpd); //连接主机 
mysql_select_db($dbname); //选择数据库 
mysql_query("SET NAMES 'utf8'"); 
display_tree("├",0); 
function display_tree($tag,$classid) { 
$result = mysql_query(" 
SELECT * 
FROM ylmf_class 
WHERE parentid = '" . $classid . "' 
;" 
); 
while ($row = mysql_fetch_array($result)) { 
// 缩进显示节点名称 
echo $tag.$row['classname'] . "<br/>"; 
//再次调用这个函数显示子节点的子节点 
display_tree($tag."─┴",$row['id']); 
} 
} 
?>

这样递归方法,对于大量的子栏目是个负担,一些成熟的cms系统。都是生产数组方便调用,也能大幅的提高效率。
PHP 相关文章推荐
小偷PHP+Html+缓存
Dec 20 PHP
PHPMailer 中文使用说明小结
Jan 22 PHP
php IP转换整形(ip2long)的详解
Jun 06 PHP
php+MySQL判断update语句是否执行成功的方法
Aug 28 PHP
PHP分页类集锦
Nov 18 PHP
ThinkPHP添加更新标签的方法
Dec 05 PHP
php中mail函数发送邮件失败的解决方法
Dec 24 PHP
PHP实现合并discuz用户
Aug 05 PHP
Yii净化器CHtmlPurifier用法示例(过滤不良代码)
Jul 15 PHP
PHP页面跳转操作实例分析(header方法)
Sep 28 PHP
thinkphp查询,3.X 5.0方法(亲试可行)
Jun 17 PHP
利用Homestead快速运行一个Laravel项目的方法详解
Nov 14 PHP
php下尝试使用GraphicsMagick的缩略图功能
Jan 01 #PHP
PHP读取XML值的代码(推荐)
Jan 01 #PHP
PHP中simplexml_load_string函数使用说明
Jan 01 #PHP
php xml 入门学习资料
Jan 01 #PHP
PHP+SQL 注入攻击的技术实现以及预防办法
Dec 29 #PHP
解决PHP在DOS命令行下却无法链接MySQL的技术笔记
Dec 29 #PHP
window+nginx+php环境配置 附配置搭配说明
Dec 29 #PHP
You might like
再次研究下cache_lite
2007/02/14 PHP
php google或baidu分页代码
2009/11/26 PHP
在PHP中检查PHP文件是否有语法错误的方法
2009/12/23 PHP
PHP5.3.1 不再支持ISAPI
2010/01/08 PHP
用PHP将数据导入到Foxmail的实现代码
2010/09/05 PHP
PHP实现的同步推荐操作API接口案例分析
2016/11/30 PHP
php在windows环境下获得cpu内存实时使用率(推荐)
2018/02/08 PHP
关于PHP5.6+版本“No input file specified”问题的解决
2019/12/11 PHP
js类中的公有变量和私有变量
2008/07/24 Javascript
JS去除字符串的空格增强版(可以去除中间的空格)
2009/08/26 Javascript
JavaScript instanceof 的使用方法示例介绍
2013/10/23 Javascript
javascript的回调函数应用示例
2014/02/20 Javascript
AngularJS使用angular-formly进行表单验证
2015/12/27 Javascript
Javascript基础_简单比较undefined和null 值
2016/06/14 Javascript
JavaScript 字符串常用操作小结(非常实用)
2016/11/30 Javascript
js实现点击按钮弹出上传文件的窗口
2016/12/23 Javascript
Vue网页html转换PDF(最低兼容ie10)的思路详解
2017/08/24 Javascript
js es6系列教程 - 基于new.target属性与es5改造es6的类语法
2017/09/02 Javascript
详解使用Vue Router导航钩子与Vuex来实现后退状态保存
2017/09/11 Javascript
JS基于对象的特性实现去除数组中重复项功能详解
2017/11/17 Javascript
Nodejs中crypto模块的安全知识讲解
2018/01/03 NodeJs
jquery实现垂直手风琴导航栏
2020/02/18 jQuery
jQuery实现简单轮播图效果
2020/12/27 jQuery
跟老齐学Python之for循环语句
2014/10/02 Python
Python实现连接两个无规则列表后删除重复元素并升序排序的方法
2018/02/05 Python
详解Django的model查询操作与查询性能优化
2018/10/16 Python
在python中,使用scatter绘制散点图的实例
2019/07/03 Python
Python数据结构dict常用操作代码实例
2020/03/12 Python
详解python os.path.exists判断文件或文件夹是否存在
2020/11/16 Python
Etam俄罗斯:法国女士内衣和家居服网上商店
2019/10/30 全球购物
了解AppleShare protocol(AppleShare协议)吗
2015/08/28 面试题
综合测评自我鉴定
2013/10/08 职场文书
数控专业大学毕业生职业规划范文
2014/02/06 职场文书
跳槽求职信范文
2014/05/26 职场文书
车间主任岗位职责范本
2015/04/08 职场文书
2016年会开场白台词
2015/06/01 职场文书