首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

laravel生成无限级分类

无限级分类是很常见的功能,算法的好坏对于获取分类树的性能起到决定性的作用。...尤其当分类数据和层级多时,一个糟糕的算法将使服务器不堪重负 以下用laravel实现无限级分类功能,包括: 数据表设计 填充模拟数据 生成分类树 分类树的后台维护 数据表设计 字段名 描述 id 主键id...name 类目名称 parent_id 父类目 ID is_directory 是否拥有子类目 level 当前类目层级 path 该类目所有父类目 id 为什么要用level与path 无限级分类中...createCategory 方法 $this->createCategory($child, $category); // $category 为刚创建的类目,作为子类目的父级类目参数...数据填充结果 生成分类树 分类树是一个通用的功能,适合将其封装为一个服务,创建CategoryService类

2.9K40
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    PHP无限级分类函数封装与应用

    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、最终效果:     到这里就实现了一个无限下级的效果

    1.7K130

    PHP 无限级分类数据库设计及实现

    ♖背景 最近复习算法,在此对无限级分类的实现方法稍作整理,当然也是参考了道友的经验,目测适合实际的项目应用,当然,也有不少公司的笔试题还会涉及到呢,有何问题,欢迎各位道友指摘 … 操作环境: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数据显示参考: 递归方式获取 无限级分类数据

    2.1K20

    对无限级分类数据进行重新排序(非树形结构)

    无限级分类查询有很多方式。本文记录的方式是先将所有数据查出来,再使用递归对数据进行排序,并附加层级字段(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) { // 声明静态数组,避免递归调用时

    1.5K40

    PHP实现无限极分类生成分类树的方法

    本文实例讲述了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] =

    1K30

    laravel-nestedset:多级无限分类正确姿势

    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(); 让节点在父级内部上下移动来改变默认排序

    3.5K20
    领券