侯体宗的博客
  • 首页
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

php实现无限级分类查询(递归、非递归)

php  /  管理员 发布于 7年前   189

做PHP这么长时间,发现后台管理系统不可少的一个应用模块就是对栏目的分类,一般情况下栏目都要做成是无限级的,也就是说每个栏目理论上都可以添加子栏目。在我看来这种情况处理起来整体上说也不是很复杂,唯一一个相对来说较难的点是无限级栏目的查询。

下面就这种情况我来向大家做一个简单的介绍,对于这种无限级栏目的查询一般情况下有两种方式,其中一种就是使用栈的机制,另一种是使用递归函数的方式(当然递归函数实现机制也是借助于栈来实现的)。就这两种方式下面我们分别介绍。

递归函数实现方式

上面提到,递归函数的也是借助于栈的机制实现的,但是底层对于栈的处理对于程序员来说都是透明的,程序员只需要关心应用的实现逻辑。所以说使用递归处理上述问题理解起来比较容易,代码也比较简洁。

既然使用递归函数,看名字我们就知道必须借助于自定义的函数。我先大概说一下其实现思路,具体细节我们反映在代码中。

对于每一层的函数其主要做的工作就是查找父Id为当前Id的栏目,查找到以后再次调用自身函数,将查找到的栏目的id作为下一层的父id。

其流程图如下

图一

不知道对于上面的解释大家能不能理解,没关系我们下面直接看代码

1,'name'=>"衣服",'parId'=>0),  array('id'=>2,'name'=>"书籍",'parId'=>0),  array('id'=>3,'name'=>"T恤",'parId'=>1),  array('id'=>4,'name'=>"裤子",'parId'=>1),  array('id'=>5,'name'=>"鞋子",'parId'=>1),  array('id'=>6,'name'=>"皮鞋",'parId'=>5),  array('id'=>7,'name'=>"运动鞋",'parId'=>5),  array('id'=>8,'name'=>"耐克",'parId'=>7),  array('id'=>9,'name'=>"耐克",'parId'=>3),  array('id'=>10,'name'=>"鸿星尔克",'parId'=>7),  array('id'=>11,'name'=>"小说",'parId'=>2),  array('id'=>12,'name'=>"科幻小说",'parId'=>11),  array('id'=>13,'name'=>"古典名著",'parId'=>11),  array('id'=>14,'name'=>"文学",'parId'=>2),  array('id'=>15,'name'=>"四书五经",'parId'=>14));$html = array();/** * 递归查找父id为$parid的结点 * @param array $html  按照父-》子的结构存放查找出来的结点 * @param int $parid  指定的父id * @param array $channels  数据数组 * @param int $dep  遍历的深度,初始化为1 */function getChild(&$html,$parid,$channels,$dep){  /*   * 遍历数据,查找parId为参数$parid指定的id   */  for($i = 0;$i$channels[$i]['id'],'name'=>$channels[$i]['name'],'dep'=>$dep);      getChild($html,$channels[$i]['id'],$channels,$dep+1);    }  }}getChild($html,0,$channels,1);?>

这是递归实现无限级栏目查询的核心代码,结合图一对其实现流程应该有一个较清晰的认识。

非递归,即使用栈机制实现无限级栏目的查询

在上面我们大概介绍了一下使用递归的方式实现无限级栏目的查询,下面我们简单介绍一下非递归的方式。虽说不用递归函数的方式,但是鉴于无限级栏目的结构页需要参考递归的实现机制――栈的机制,解决这一问题。

在上学的时候老师就说,其实栈的核心机制也就四个字:先进后出。

在这对于栈的机制不多说,主要说一下如何借助栈实现无限级栏目查询。

1. 首先将顶级栏目压入栈中

2. 将栈顶元素出栈

3. 将出栈元素存入数组中,标记其深度(其深度就是在其父栏目的深度上面加1)

4. 以出栈的元素为父栏目,查找其子栏目

5. 将查找到的子栏目入栈,重复步骤2

6. 判断栈为空的话,流程结束;

通过对以上步骤的翻译,可以将这些步骤翻译成PHP代码,其核心代码如下

1,'name'=>"衣服",'parId'=>0),  array('id'=>2,'name'=>"书籍",'parId'=>0),  array('id'=>3,'name'=>"T恤",'parId'=>1),  array('id'=>4,'name'=>"裤子",'parId'=>1),  array('id'=>5,'name'=>"鞋子",'parId'=>1),  array('id'=>6,'name'=>"皮鞋",'parId'=>5),  array('id'=>7,'name'=>"运动鞋",'parId'=>5),  array('id'=>8,'name'=>"耐克",'parId'=>7),  array('id'=>9,'name'=>"耐克",'parId'=>3),  array('id'=>10,'name'=>"鸿星尔克",'parId'=>7),  array('id'=>11,'name'=>"小说",'parId'=>2),  array('id'=>12,'name'=>"科幻小说",'parId'=>11),  array('id'=>13,'name'=>"古典名著",'parId'=>11),  array('id'=>14,'name'=>"文学",'parId'=>2),  array('id'=>15,'name'=>"四书五经",'parId'=>14));$stack = array(); //定义一个空栈$html = array();  //用来保存各个栏目之间的关系以及该栏目的深度/* * 自定义入栈函数 */function pushStack(&$stack,$channel,$dep){  array_push($stack, array('channel'=>$channel,'dep'=>$dep));}/* * 自定义出栈函数 */function popStack(&$stack){  return array_pop($stack);}/* * 首先将顶级栏目压入栈中 */foreach($channels as $key=>$val){  if($val['parId'] == 0)    pushStack($stack,$val,0);}/* * 将栈中的元素出栈,查找其子栏目 */do{  $par = popStack($stack); //将栈顶元素出栈  /*   * 查找以此栏目为父级栏目的id,将这些栏目入栈   */  for($i=0;$i$par['channel']['id'],'name'=>$par['channel']['name'],'dep'=>$par['dep']);}while(count($stack)>0);

上面就是使用非递归方式实现的。

下载代码:https://github.com/onmpw/phpApp

总结

上面两种方式各有利弊,虽然实现形式上面不同,但是鉴于无限级栏目的结构,二者实现的机制都是相同的――都借助栈的方式来实现。在现实情况中,我们要根据现实情况的需要选择一种方式来实现。

您可能感兴趣的文章:

  • php实现斐波那契数列的简单写法
  • php处理斐波那契数列非递归方法
  • php实现斐波那契数列代码分享
  • php递归使用示例(php递归函数)
  • php实现递归的三种基本方式
  • PHP经典算法集锦【经典收藏】
  • PHP面试常用算法(推荐)
  • 使用PHP实现二分查找算法代码分享
  • PHP常用算法和数据结构示例(必看篇)
  • php求斐波那契数的两种实现方式【递归与递推】


  • 上一条:
    PHP中调用C/C++制作的动态链接库的教程
    下一条:
    PHP浮点数的一个常见问题
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 用Time Warden监控PHP中的代码处理时间(0个评论)
    • 在PHP中使用array_pop + yield实现读取超大型目录功能示例(0个评论)
    • Property Hooks RFC在PHP 8.4中越来越接近现实(0个评论)
    • 近期文章
    • 在windows10中升级go版本至1.24后LiteIDE的Ctrl+左击无法跳转问题解决方案(0个评论)
    • 智能合约Solidity学习CryptoZombie第四课:僵尸作战系统(0个评论)
    • 智能合约Solidity学习CryptoZombie第三课:组建僵尸军队(高级Solidity理论)(0个评论)
    • 智能合约Solidity学习CryptoZombie第二课:让你的僵尸猎食(0个评论)
    • 智能合约Solidity学习CryptoZombie第一课:生成一只你的僵尸(0个评论)
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(95个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-06
    • 2017-07
    • 2017-08
    • 2017-09
    • 2017-11
    • 2017-12
    • 2018-01
    • 2018-02
    • 2018-03
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-09
    • 2021-02
    • 2021-03
    • 2021-04
    • 2021-05
    • 2021-06
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-08
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    • 2024-05
    • 2024-06
    • 2024-07
    • 2024-09
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客