无限级分类
是一种很常见,很必须的功能,几乎每个项目都有。
应用场景:下拉列表,树型列表等
无限级分类的类型前端实现(前端框架一般已经实现好了,只要后端按照指定格式传数据给前端就可以生成了)
后端实现(下面主要讲这种实现)
无限级多种实现第一种(推荐)
function infiniteSort($data, $showFName, $titleFName, $pidFName = "pid", $idFName = "id", $levelFName = "level", $pid = 0, $level = 0) { $tree = array(); foreach ($data as $key => $value) { if ($value[$pidFName] == $pid) { $value[$levelFName] = $level; $value[$showFName] = str_repeat(" ", $level) . "|-" . $value[$titleFName]; $tree[] = $value; unset($data[$key]); $tempArr = infiniteSort($data, $showFName, $titleFName, $pidFName, $idFName, $level, $value[$idFName], $level + 1); if(!empty($tempArr)){ $tree = array_merge($tree, $tempArr); } } } return $tree; }
注意:
1、$data 已经asc排序过的所有数据
2、$showFName 显示名字的字段名(格式化过的)
3、$titleFName 标题的字段名(无格式化)
4、$levelFName 层级字段名
5、$pidFName 父id的字段名
6、$idFName id的字段名
第二种(使用引用变量)
/** * 无限级分类 * @param Array $treeList //接受处理完成数据的数组 * @param Array $data //数据库里获取的结果集 * @param String $level //格式化层级字段名 * @param Int $pid * @param Int $count //第几级分类 */ function tree(&$treeList, &$data, $level, $show_name, $field_name, $field_pid = "pid", $field_id = "id", $pid = 0, $count = 0) { foreach ($data as $key => $value) { if ($value[$field_pid] == $pid) { $value[$level] = $count; $value[$show_name] = str_repeat(" ",$count)."|-".$value[$field_name]; $treeList[] = $value; unset($data[$key]); tree($treeList, $data, $level, $show_name, $field_name,$field_pid, $field_id, $value[$field_id], $count+1); } } }
注意:
1、$data 已经asc排序过的所有数据
2、返回的无限级列表数据都存在$treeList里面
第三种(使用静态变量有限制:如果一次请求调用两次来实现2个无限级分类就会出现问题,所以不推荐)
public function getTree($list, $parent_id, $level=0) { //应该是静态的局部变量,这样才能保证,在递归调用时,所有 //的getTree方法,操作的是一个Tree空间。 static $tree = array();//保存找到的分类的数组 //遍历所有分类,通过parent_id判断,哪些是我们正在查找的 foreach($list as $row) { //判断当前所遍历的分类$row, 是否是当前需要查找的子分类 if($row["pid"] == $parent_id) { //找到了一个分类 //存起来,存哪? $row["level"] = $level; $tree[] = $row; //继续查找当前$row所代表的分类的子分类 $this->getTree($list, $row["id"], $level+1); } } return $tree; }
注意:
1、$list 已经asc排序过的所有数据
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/22324.html
摘要:我们在新建一个删除前的钩子函数,再利用递归方法实现子栏目的删除。最后我们删除把钩子函数恢复到原始状态在浏览器中输入,然后点击美国一栏中的删除,此时会同时删除美国下的纽约。至此,无限级分类的删除功能操作完毕。 在此现更正一下之前的预告,之前忘记了先应该把无限级分类栏目列表功能做完,也就是删除功能还没做,所以今天我们先做删除,下一节再做面包屑导航。非常抱歉。 同时,不知道是什么原因,上一节...
摘要:可以看到,我们首先获取到了所有的数据,然后按照父级归类。无限嵌套评论先来看下这个无限嵌套评论长什么样子。文件扫描使用递归进行目录文件的扫描的栗子。 回顾 上一篇文章我们讲到实战PHP数据结构基础之递归。来回顾下什么是递归? 一般来说,递归被称为函数自身的调用。 递归在开发中的实际运用 N级分类 无限级的分类在平常的开发中是常见的需求,并且在不少面试题中都会碰到。不管你做什么项目,应该都...
摘要:可以看到,我们首先获取到了所有的数据,然后按照父级归类。无限嵌套评论先来看下这个无限嵌套评论长什么样子。文件扫描使用递归进行目录文件的扫描的栗子。 回顾 上一篇文章我们讲到实战PHP数据结构基础之递归。来回顾下什么是递归? 一般来说,递归被称为函数自身的调用。 递归在开发中的实际运用 N级分类 无限级的分类在平常的开发中是常见的需求,并且在不少面试题中都会碰到。不管你做什么项目,应该都...
摘要:有这样一个表,是分类的,是分类名称,是上级分类的。现在有个分类,程序要找到它上级的上级的上级分类的,简单说就是找出顶级分类的。比如新鲜水果的是,对应父类是,而的父是,没有父类,也就是顶级分类了。 有这样一个表,id是分类的ID,name是分类名称,pid是上级分类的ID。showImg(https://segmentfault.com/img/bVtnrg); 现在有个分类ID,程序要...
阅读 2892·2021-10-18 13:33
阅读 843·2019-08-30 14:20
阅读 2623·2019-08-30 13:14
阅读 2514·2019-08-29 18:38
阅读 2881·2019-08-29 16:44
阅读 1208·2019-08-29 15:23
阅读 3468·2019-08-29 13:28
阅读 1912·2019-08-28 18:00