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 相关文章推荐
递归列出所有文件和目录
Oct 09 PHP
VFP与其他应用程序的集成
Oct 09 PHP
超级简单的发送邮件程序
Oct 09 PHP
删除数组元素实用的PHP数组函数
Aug 18 PHP
php下删除字符串中HTML标签的函数
Aug 27 PHP
PHP初学者常见问题集合 修正版(21问答)
Mar 23 PHP
一个PHP验证码类代码分享(已封装成类)
Jul 17 PHP
PHP下SSL加密解密、验证、签名方法(很简单)
Jun 28 PHP
PHP正则表达式过滤html标签属性(DEMO)
May 04 PHP
阿里云的WindowsServer2016上部署php+apache
Jul 17 PHP
PHPStudy下如何为Apache安装SSL证书的方法步骤
Jan 23 PHP
php实现根据身份证获取精准年龄
Feb 26 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
PHP实现递归复制整个文件夹的类实例
2015/08/03 PHP
使用symfony命令创建项目的方法
2016/03/17 PHP
DWZ+ThinkPHP开发时遇到的问题分析
2016/12/12 PHP
PHP iconv()函数字符编码转换的问题讲解
2019/03/22 PHP
PHP 加密 Password Hashing API基础知识点
2020/03/02 PHP
静态的动态续篇之来点XML
2006/08/15 Javascript
JQuery 选择器 xpath 语法应用
2010/05/13 Javascript
jQuery关于导航条背景切换效果实现示例
2013/09/04 Javascript
Jquery实现自定义窗口随意的拖拽
2014/03/12 Javascript
jQuery中:radio选择器用法实例
2015/01/03 Javascript
详解Javascript中的Object对象
2016/02/28 Javascript
bootstrap模态框跳转到当前模板页面 框消失了而背景存在问题的解决方法
2020/11/30 Javascript
AngularJS中的Promise详细介绍及实例代码
2016/12/13 Javascript
AngularJS通过ng-route实现基本的路由功能实例详解
2016/12/13 Javascript
JS中IP地址与整数相互转换的实现代码
2017/04/10 Javascript
jQuery 控制文本框自动缩小字体填充
2017/06/16 jQuery
React Native第三方平台分享的实例(Android,IOS双平台)
2017/08/04 Javascript
vue实现的上传图片到数据库并显示到页面功能示例
2018/03/17 Javascript
WebPack配置vue多页面的技巧
2018/05/15 Javascript
jQuery实现的点击图片居中放大缩小功能示例
2019/01/16 jQuery
JavaScript设计模式之装饰者模式实例详解
2019/01/17 Javascript
javascript防抖函数debounce详解
2019/06/11 Javascript
Python中使用动态变量名的方法
2014/05/06 Python
python的描述符(descriptor)、装饰器(property)造成的一个无限递归问题分享
2014/07/09 Python
Python简单检测文本类型的2种方法【基于文件头及cchardet库】
2016/09/18 Python
对python判断是否回文数的实例详解
2019/02/08 Python
Python标准库使用OrderedDict类的实例讲解
2019/02/14 Python
Keras—embedding嵌入层的用法详解
2020/06/10 Python
CSS3 边框效果
2019/11/04 HTML / CSS
技校教师求职简历的自我评价
2013/10/20 职场文书
中学实习教师自我鉴定
2013/12/12 职场文书
女子职高个人自荐书
2014/02/01 职场文书
四年级语文教学反思
2014/02/05 职场文书
《最佳路径》教学反思
2014/04/13 职场文书
放飞梦想演讲稿200字
2014/08/26 职场文书
CAD实训总结范文
2015/08/03 职场文书