利用函数递归实现无限分类
来源:互联网 发布:易观千帆数据哪来的 编辑:程序博客网 时间:2024/06/05 11:11
<span style="font-size:18px;">/**利用函数递归的思想创建一个函数实现无限分类的功能*其实就是以每条数据的f_id父id作为根节点,进行数据的串联,再以根节*点向下查找***举例:id f_id title* 1 0 陕西* 2 0 山西* 3 1 西安* 4 1 渭南* 5 2 山西*我们以省市划分举例,id代表每条记录的序号,f_id代表父id,取值取得*是它的上一级区域的id。 仔细观察即可发现规律* 个人理解,希望可以帮助有需求的人*///创建一个函数两个参数 $arr 将分类的数组 $p_id 初始父id</span>
<span style="font-size:18px;"></span>
<span style="font-size:18px;">function get_fenlei($arr,$p_id=0){//采用foreach()循环打印$arr数组foreach ($arr as $value) { //首先我们寻找f_id==0的记录,因为它们是最高的,所以分别以它们 //为根节点向下寻找子节点,即就是利用函数递归,寻找 //属于直辖下的城市if($value['p_id']==$p_id){//f_is==0执行 if($value['p_id']==0){//为了显示效果,不是核心代码 echo "</br>".$value['title'];//显示title }else{ echo "</br>--------".$value['title']; } //函数递归,此时以根节点的id作为父id寻找它下面的城市 //核心代码,如此递归 显示无限分类 get_fenlei($arr,$value['id']);}}}//我们就不用操作数据库了,用一个数组代替就可以了$arr=array(array('id'=>'1','p_id'=>'0','title'=>'陕西'),array('id'=>'2','p_id'=>'0','title'=>'山西'), array('id'=>'3','p_id'=>'1','title'=>'西安'), array('id'=>'4','p_id'=>'1','title'=>'渭南'), array('id'=>'5','p_id'=>'2','title'=>'大同'));//执行函数get_fenlei($arr);</span>
<span style="font-size:18px;">效果图:</span>
0 0
- 利用函数递归实现无限分类
- 利用引用和递归实现无限极分类
- 编写一个函数,递归遍历,实现无限分类(新浪)
- 递归实现无限级别分类
- 递归实现之无限分类
- 递归实现无限极分类
- 递归实现无限极分类
- 无限分类递归的实现
- c# 菜单无限极分类-利用递归
- 实现无限极分类-递归实现
- php 递归 实现无限分类 格式化数组
- 【php】php递归实现的无限分类
- PHP无限分类——递归实现
- PHP递归实现无限级分类
- PHP递归实现无限级分类
- PHP递归实现无限级分类
- 用递归的方法实现无限分类
- PHP递归实现无限级分类
- http上传文件和进度监控以及构造multipart/form-data请求
- 关于Sql Server2008升级成企业版本后,通过命令查询还是“快版”的说明
- 设计模式之享元模式
- elasticsearch 警告 org.jboss.netty.handler.codec.frame.TooLongFrameException: HTTP content length exce
- [C#] 如何分析stackoverflow等clr错误
- 利用函数递归实现无限分类
- Suricata规则编写——数据包头部关键字
- 使用STM32CUBEMX生成FatFS代码,操作SPI FLASH
- iOS文件操作(更新中)
- 新浪微博api使用
- 锁与事务处理
- easyui treegrid 封装(不用分页,用加载更多按钮)延迟加载加加载更多
- HTTP Response Status Code -- HTTP响应代码中文详解