0

0

php利用递归函数实现无限级归类

php中文网

php中文网

发布时间:2016-06-13 12:23:34

|

1175人浏览过

|

来源于php中文网

原创

php利用递归函数实现无限级分类

  相信很多学php的很多小伙伴都会尝试做一个网上商城作为提升自己技术的一种途径。各种对商品分类,商品名之类的操作应该是得心应手,那么就可以尝试下无限级分类列表的制作了。

  什么是无限级分类?

  无限级分类是一种分类技巧,例如部门组织,文章分类,学科分类等常用到无限级分类,将其简单理解成分类就好了。其实我们仔细想一下,生活中的分类简直太多了,衣服可以分为男装和女装,也可以分为上衣和裤子,也可以根据年龄段分类。分类无处不在,分类显得“无限”。我这里就不说无限分类的必要性了。

  无限级分类原理简介

  无限分类看似"高大上",实际上原理是非常简单的 。无限分类不仅仅需要代码的巧妙性,也要依托数据库设计的合理性。要满足无限级分类,数据库需要有两个必须的字段,id,pid。id用来标识自身,而pid则是用来表明父级id。也就是说,每个分类记录不仅描述了自身,还描述了与其关心最为紧密的另一个id。看似复杂的事情被这样一个小技巧解决了。

立即学习PHP免费学习笔记(深入)”;

  闲话不多说,该展现本文的实例了。

  作为一个狂热海贼迷,这篇的实例我就以《海贼王》人物组织做案例。

  数据库准备: 

  建表onepiece:

永利在线企业网站管理系统(CMS)1.0 Build 20100612
永利在线企业网站管理系统(CMS)1.0 Build 20100612

修正说明:1,实现真正的软件开源。2,安装界面的美化3,真正实现栏目的递归无限极分类。4,后台添加幻灯片图片的管理,包括添加,修改,删除等。5,修正添加新闻的报错信息6,修正网站参数的logo上传问题7,修正产品图片的栏目无限极分类8,修正投票系统的只能单选问题9,添加生成静态页功能10,添加缓存功能特点和优势1. 基于B/S架构,通过本地电脑、局域网、互联网皆可使用,使得企业的管理与业务不受地域

下载
create table onepiece(    id int auto_increment,    pid int not null,    name varchar(225) not null,    primary key(id));

   插入测试数据:

insert onepiece values    (1,0,'海军'),    (2,0,'海贼'),    (3,0,'革命军'),    (4,1,'青雉'),    (5,1,'赤犬'),    (6,1,'黄猿'),    (7,2,'四皇'),    (8,2,'七武海'),    (9,2,'草帽海贼团'),    (10,9,'索隆'),    (11,7,'香克斯'),    (12,8,'多弗朗明哥'),    (13,8,'克洛克达尔');

  这里还是科普下海贼王里面的设定:世界分为三大阵营:海军,海贼,革命军。海军有大将:青雉,赤犬,黄猿。海贼有:四皇,七武海,草帽海贼团。四皇有香克斯,七武海有多弗朗明哥,克洛克达尔,草帽海贼团有索隆。(打个广告:海贼王真的很好看)。

  最终目的:

  我们今天制作的是两种形式的无限级分类形式,一种是下拉列表式,一种则是导航Link式的。直接上效果图了:

下拉列表式导航Link式

  实例代码:

  我封装了一个Unlimited类,用来调用diaplayList()展现下拉列表形式,调用diaplayLink展现导航Link分类。也可以增加(addNodes())和删除(deleteNodes)分类。

  

phpclass Unlimited{    protected $mysqli;    public function __construct($config){        $this->mysqli=new mysqli($config['host'],$config['user'],$config['pwd']);        $this->mysqli->select_db($config['db']);        $this->mysqli->set_charset('utf8');        if ($this->mysqli->connect_errno) {            echo $this->mysqli->connect_error;        }    }        private function getList($pid=0,&$result=array(),$spac=0){        $spac=$spac+2;        $sql="select * from onepiece where pid={$pid}";        $rs=$this->mysqli->query($sql);        while($row=$rs->fetch_assoc()) {            $row['name']=str_repeat('  ',$spac).$row['name'];            $result[]=$row;            $this->getList($row['id'],$result,$spac);                    }        return $result;    }    /**     * 展现下拉列表式分类     * @return [type]      */    public function displayList(){        $rs=$this->getList();        $str="";        return $str;    }    private function getLink($cid,&$result=array()){        $sql="select * from onepiece where id={$cid}";        $rs=$this->mysqli->query($sql);        if($row=$rs->fetch_assoc()){            $result[]=$row;            $this->getLink($row['pid'],$result);        }        return array_reverse($result);    }    /**     * 展现导航Link     * @param  [type] $cid [description]     * @return [type]      [description]     */    public function displayLink($cid){        $rs=$this->getLink($cid);        $str='';        foreach ($rs as $val) {            $str.="{$val['name']}>";        }        return $str;    }    /**     * 增加分类     * @param [type] $pid  父类id     * @param [type] $name 本类名     */    public function addNodes($pid,$name){        $sql="insert into onepiece values('',{$pid},'".$name."')";        if($this->mysqli->query($sql)){            return true;        }    }    /**     * 删除分类     * @param  [type] $id 本类id     * @return [type]          */    public function deleteNodes($id){        $sql="select * from onepiece where pid ={$id}";        $rs=$this->mysqli->query($sql);        if($row=$rs->fetch_assoc()){            $mes="还有子元素,请勿删除";        }else{            $sql="delete from onepiece where id={$id}";            if($this->mysqli->query($sql)){                $mes="删除成功";            }        }        return $mes;    }}

  类中函数主要采取了递归函数的方法,如果理解深刻理解递归函数,其余的部分也就水到渠成了。我会在后面的部分详细介绍实现递归函数的三种方法。

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
虚拟号码教程汇总
虚拟号码教程汇总

本专题整合了虚拟号码接收验证码相关教程,阅读下面的文章了解更多详细操作。

29

2025.12.25

错误代码dns_probe_possible
错误代码dns_probe_possible

本专题整合了电脑无法打开网页显示错误代码dns_probe_possible解决方法,阅读专题下面的文章了解更多处理方案。

20

2025.12.25

网页undefined啥意思
网页undefined啥意思

本专题整合了undefined相关内容,阅读下面的文章了解更多详细内容。后续继续更新。

37

2025.12.25

word转换成ppt教程大全
word转换成ppt教程大全

本专题整合了word转换成ppt教程,阅读专题下面的文章了解更多详细操作。

6

2025.12.25

msvcp140.dll丢失相关教程
msvcp140.dll丢失相关教程

本专题整合了msvcp140.dll丢失相关解决方法,阅读专题下面的文章了解更多详细操作。

2

2025.12.25

笔记本电脑卡反应很慢处理方法汇总
笔记本电脑卡反应很慢处理方法汇总

本专题整合了笔记本电脑卡反应慢解决方法,阅读专题下面的文章了解更多详细内容。

6

2025.12.25

微信调黑色模式教程
微信调黑色模式教程

本专题整合了微信调黑色模式教程,阅读下面的文章了解更多详细内容。

5

2025.12.25

ps入门教程
ps入门教程

本专题整合了ps相关教程,阅读下面的文章了解更多详细内容。

4

2025.12.25

苹果官网入口直接访问
苹果官网入口直接访问

苹果官网直接访问入口是https://www.apple.com/cn/,该页面具备0.8秒首屏渲染、HTTP/3与Brotli加速、WebP+AVIF双格式图片、免登录浏览全参数等特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

218

2025.12.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
AngularJS教程
AngularJS教程

共24课时 | 2万人学习

CSS3实现按钮特效视频教程
CSS3实现按钮特效视频教程

共15课时 | 3.2万人学习

细说PHP第三季
细说PHP第三季

共58课时 | 11.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号