无限级分类数据 ---- 本文章中的算法使用的都是以下数据 站长源码网 $array = [ 2....使用引用算法转为无限级分类树 ---- $data = getTree($data); /** 收藏 | 0点赞 | 0打赏
无限级分类是很常见的功能,算法的好坏对于获取分类树的性能起到决定性的作用。...尤其当分类数据和层级多时,一个糟糕的算法将使服务器不堪重负 以下用laravel实现无限级分类功能,包括: 数据表设计 填充模拟数据 生成分类树 分类树的后台维护 数据表设计 字段名 描述 id 主键id...name 类目名称 parent_id 父类目 ID is_directory 是否拥有子类目 level 当前类目层级 path 该类目所有父类目 id 为什么要用level与path 无限级分类中...createCategory 方法 $this->createCategory($child, $category); // $category 为刚创建的类目,作为子类目的父级类目参数...数据填充结果 生成分类树 分类树是一个通用的功能,适合将其封装为一个服务,创建CategoryService类
摘要 在实际项目中经常要用到无限级分类,如多级分类、导航表等。PHP 实现无限级分类通常有两种实现方式,一种是利用path字段(pid+id)标识当前层级;另一种是利用递归循环pid的方式。...PHP 实现无限级分类 – path标识 1、数据库设计 --创建分类表 create table `b_category`( `id` int primary key not null auto_increment...`cat_description` text default '', `level` int not null default 0 comment '等级', `pid` int comment '父级id...', `path` varchar(10) comment 'pid+,+id标识,用于无限级分类' ); 2、PHP 代码实现 $data = $m->field("*, concat(path,'...select-box"> 顶级分类
ASC,id ASC //这里的排序是至关重要的 Step 3、查询出的结果是一个常规的二维数组,如下图: ps:pid就是parent_id,这里是举个例子,下文一样 Step 4、封装的无限级分类数组处理函数...: /** * 无限级分类 * * @access public * @param Array $data * //数据库里获取的结果集... * @param Int $pid * @param Int $count * //第几级分类 * @return Array $treeList... */ // 存放无限分类结果如果一页面有多个无限分类可以使用 Tool::$treeList = array(); 清空 public static $treeList =... ├ {$dlist.class_name} Step 8、最终效果: 到这里就实现了一个无限下级的效果
♖背景 最近复习算法,在此对无限级分类的实现方法稍作整理,当然也是参考了道友的经验,目测适合实际的项目应用,当然,也有不少公司的笔试题还会涉及到呢,有何问题,欢迎各位道友指摘 … 操作环境:Win10...首先,实现无限级分类的方式有: 以父ID设计,运用递归实现的方式 以全路径实现的无限分类方式 ②....父ID 方式 核心处理代码如下,注意参数备注信息,便于正确的调用 /** * 数据库设计 递归方式 获取无限极分类数据 由上到下进行获取 * @param int $pid...父级ID,默认为根级分类 0 * @param int $sel_id 所选中的分类ID,多用于前端 selected 标识 * @param array $result 数组整合...deepCatesForDown(0,6); $this->assign('cateListDown',$cateListDown); $this->display(); 前端Html数据显示参考: 递归方式获取 无限级分类数据
ret = ''; /** 构造函数,初始化类 @param array 2维数组,例如: array( 1 => array('id'=>'1','parentid'=>0,'name'=>'一级栏目一...'), 2 => array('id'=>'2','parentid'=>0,'name'=>'一级栏目二'), 3 => array('id'=>'3','parentid'=>1,'name'=>'...二级栏目一'), 4 => array('id'=>'4','parentid'=>1,'name'=>'二级栏目二'), 5 => array('id'=>'5','parentid'=>2,'name...'=>'二级栏目三'), 6 => array('id'=>'6','parentid'=>3,'name'=>'三级栏目一'), 7 => array('id'=>'7','parentid'=>3,...'name'=>'三级栏目二') ) */ function tree($arr=array()) { $this->arr = $arr; $this->ret = ''; return is_array
无限级分类树状结构的应用场景很多,例如后端研发需要把用户相关权限读取出来并生成树状结构,前端研发拿到权限树之后可以按照结构展示用户有权限访问的栏目;再例如网页上的栏目分级: 作者在初次接触树状结构生成需求的时候...child"] = generate_tree(source, item["id"], cache) tree.append(item) return tree 至此,无限级分类树状结构生成算法完成
无限级分类查询有很多方式。本文记录的方式是先将所有数据查出来,再使用递归对数据进行排序,并附加层级字段(level)。此方式仅仅对无限级的数据进行排序,并没有将子级内容放入父级。 1....在 TP6.0 中使用的 对无限级分类进行排序,并附加层级字段 ---- <?...CategoryModel::field('id,pid,name') ->order('sort desc') ->select(); $data = $this->_sort($data);//对无限级分类重新排序...dump($data); } /** * 无限级分类递归排序 */ private function _sort($data, $pid = 0, $level = 0) { static $arr...其他写法 ---- /** * 无限级分类排序 */ private function getTree($array, $pid = 0, $level = 0) { // 声明静态数组,避免递归调用时
-- 最后一级 --> {{item.menuName}}</el-menu-item
导读:说到无限极分类,这个在程序中是常见的一个功能点了。实现的方式也有很多种,今天着重分享一下涉及到数据库的无线分类,可以使用递归处理,也可以使用循环查询数据库处理。..., 0, 'icons/18.gif'), (3, 0, '生活点滴', '记录生活点滴', 0, 'icons/2.gif'), (6, 0, '栀子花开', '青春无限', 0, 'icons/8....'] = getTree($data, $v['cate_Id']); $tree[] = $v; } } return $tree; } // 这里的0就是顶级分类中的
解释核心:顶级分类0下面可以有无限个子类。这就叫无限极分类。简介来说就是中国:大的范围下>>的小范围:海南吧。...想这张图一样,核心在于,从顶级分类pid=0开始起,顶级分类中的id是找到所有的相同的pid为子类,然后这些子类的id又会找到下一层级的pid(顶级分类pid=0除外,因为他上面已经没有id了)。...php $db_host="localhost"; $db_user="root"; $db_password=""; $db_name="book"; $link=mysql_connect($db_host...,$db_user,$db_password) or die(mysql_error); mysql_select_db($db_name,$link) or die(mysql_error()); mysql_query...($sql); while($row =mysql_fetch_assoc($res)) { $row['catename']=str_repeat(" ",$
近开发商品功能,在尝试递归和引用方式后,蓦然回首,突然发现 laravel 框架有更简单高效的实现方式,无限极分类最佳实践,open code 与大家共享!...', `pid` int(5) unsigned DEFAULT '0' COMMENT '父级id', `level` tinyint(3) unsigned DEFAULT '1' COMMENT...'分类等级', `status` tinyint(3) unsigned DEFAULT '0' COMMENT '分类状态:0-禁用,1-正常', `created_at` timestamp...// 控制器 $list = GoodsCategory::with('allChildren')->first(); dd($list); 处理后数据: 至此,laravel 框架无限极分类实现完毕...,相比递归和引用实现无限极分类的两种方式,是不是简单高效很多呢,关于更多 laravel 特性,欢迎评论区留言探讨。
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/169571.html原文链接:https://javaforall.cn
"; tree($list,$v["id"]); echo ""; } } echo ""; } //首先把所有的数据取出来,从第一级开始
效果预览 先来看垂直方向无限级菜单目录 ? 再来看水平方向无限级菜单目录: ?...总结 本文给出了无限层级菜单的终极方案。该方案可以支持大型系统的构建。 赶快动手试试吧。
本文实例讲述了PHP实现无限极分类生成分类树的方法。...分享给大家供大家参考,具体如下: 现在的分类数据库设计基本都是:每一个分类有一个id主键字段,一个pid指向父类的id,这样便可实现无限级分类,取出的数据就是如下的格式: $arr = array( array..."pid" => 2 , 'cat' => '栏目十三'), array("id" => 14, "pid" => 13 , 'cat' => '栏目十四') ); 不多说,直接上处理代码: //生成无限极分类树...v){ $refer[$v['id']] = & $arr[$k]; //创建主键的数组引用 } foreach($arr as $k => $v){ $pid = $v['pid']; //获取当前分类的父级...版本可能是以前的,MYSQL建议使用5.7以上的版本】/; 13 [cat] => 栏目十四 ) ) ) ) ) [2] => Array ( [id] => 10 [pid] => 0 [cat] =
v4.3版本以后支持Laravel-5.5 v4版本支持Laravel-5.2、5.3、5.4 v3版本支持Laravel-5.1 v2版本支持Laravel-4 强烈建议使用支持事物功能的数据引擎(像MySql...添加为指定节点$neighbor的相邻节点 $neighbor必须存在,$node可以为新创建的节点,也可以为已存在的,如果$node为已存在的节点,它将移动到新的位置与$neighbor相邻,必要时它的父级将改变...rebuildSubtree($root, $data); 这将限制只重建$root子树 检索节点 在某些情况下我们需要使用变量$id代表目标节点的主键id 祖先和后代 Ancestors 创建一个节点的父级链...获得goods $goods = Goods::whereIn('category_id', $categories)->get(); 包含node深度(depth) 如果你需要知道node的出入那一层级:...$result = Category::defaultOrder()->get(); 你也可以使用倒序排序: $result = Category::reversed()->get(); 让节点在父级内部上下移动来改变默认排序
这些功能都有共同的特点: 有父子关系 可无限递归 我们以导航菜单为例, 我们将导航菜单设置为动态的, 即从动态加载菜单数据。...int primary key auto_increment, `name` varchar(20) comment '菜单名称', `pid` int default 0 comment '父级...附:模板引擎渲染 有时我们会使用模板引擎来渲染菜单, 但由于菜单是树形结构的, 所以在模板引擎中单纯的使用 for 是无法完成无限极菜单的渲染的.
https://blog.csdn.net/u011415782/article/details/53734259 背景:近期在做商品的三级分类时发现,需要将Excel表格中的数据导入到数据库中进行后期的数据操作...4.三级分类前端设计效果。 ? 5.三级分类前端代码/js ? ? 附录JS代码参考: ? ? 6.附录代码 >>>
无限级平台必须解决的一个问题,分享一下我在网上学习到的方法。...如第一步查询出B、C,第二步查询所有上级为B、C的商户(mysql的 IN 范围条件实现)。 这样的递归查询耗时是非常长的。...(个人觉得具体消耗在连接mysql数据库的次数上) 现在我们的做法是这样的:一次性查询出所有的商户信息(id、上级id),并且按正序排列(添加时间,因为要有第三级的商户必须先有第二级商户,按正序排列才可以正常得到结果
领取专属 10元无门槛券
手把手带您无忧上云