首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    laravel生成无限级分类

    无限级分类是很常见的功能,算法的好坏对于获取分类树的性能起到决定性的作用。...尤其当分类数据和层级多时,一个糟糕的算法将使服务器不堪重负 以下用laravel实现无限级分类功能,包括: 数据表设计 填充模拟数据 生成分类树 分类树的后台维护 数据表设计 字段名 描述 id 主键id...name 类目名称 parent_id 父类目 ID is_directory 是否拥有子类目 level 当前类目层级 path 该类目所有父类目 id 为什么要用level与path 无限级分类中...,我们经常需要获取一个分类的所有祖先类目或者后代类目,以及判断两个类目是否存在层级关系。...数据填充结果 生成分类树 分类树是一个通用的功能,适合将其封装为一个服务,创建CategoryService类

    2.9K40

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

    下面的讲解我用的是ThinkPHP框架,与PHP用法是一样的。...ASC,id ASC        //这里的排序是至关重要的 Step 3、查询出的结果是一个常规的二维数组,如下图: ps:pid就是parent_id,这里是举个例子,下文一样 Step 4、封装的无限级分类数组处理函数...: /**      * 无限级分类      *      * @access public      * @param Array $data      *            //数据库里获取的结果集...     */      // 存放无限分类结果如果一页面有多个无限分类可以使用 Tool::$treeList = array(); 清空     public static $treeList =...,这个函数是我从互联网上看到借鉴的,进行了一些修改,希望能够帮助大家解决工作或者学习中遇到的困难,不管是PHP还是thinkphp,用法其实一样,如果此文存在错或者有不懂的地方,可以在下方评论栏留言,我将为您解答

    1.7K130

    tp6中无限极分类里面的获取多级分类数据

    作者:陈业贵 华为云享专家 51cto(专家博主 明日之星 TOP红人) 文章目录 前言 一、什么是多级分类数据?...二、使用步骤 sql 代码 2.效果图 总结 ---- 前言 和大家共同完成获取多级分类数据 一、什么是多级分类数据? 就是很多很多的数据,按照无限极分类结构排序。...每一个数组的所有数据都是顶级分类及其其下数据 二、使用步骤 $allcate=$this->order('listorder asc')->field('id,parent_id,cate_name')...foreach ($allcate as $k => $v) { if($v['parent_id']==0){ 第二步:遍历数组并取出顶级分类的数据,放进data[]=v;这里。...foreach ($allcate as $k1 => $v1) { if($v1['parent_id']==$v['id']){ 第三步: 取出某个顶级分类其下的二级分类的所有数据

    98240

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

    ♖背景 最近复习算法,在此对无限级分类的实现方法稍作整理,当然也是参考了道友的经验,目测适合实际的项目应用,当然,也有不少公司的笔试题还会涉及到呢,有何问题,欢迎各位道友指摘 … 操作环境:Win10...使用语言:PHP 使用框架:ThinkPHP 3.2.3 ♘前期准备 ①....首先,实现无限级分类的方式有: 以父ID设计,运用递归实现的方式 以全路径实现的无限分类方式 ②....父ID 方式 核心处理代码如下,注意参数备注信息,便于正确的调用 /** * 数据库设计 递归方式 获取无限极分类数据 由上到下进行获取 * @param int $pid...全路径实现方式 对应参考上面的介绍方式,核心处理代码如下 /** * 全路径方式 获取无限极分类数据 由上到下进行获取 * @return array */ public

    2.1K20

    一段生成无限级别分类的代码思考

    我们可以看到,原本比较复杂无限级别的分类树状结构的类目被轻易实现了,我想很多小伙伴还不知道是原理是几何,下面我们对上面的代码片段进行分析。...首先是我们的区域数据$areas,数组的键必须跟元素的id键对应值相等,pid表示父元素的对应的键,当元素pid等于0时则表示它本身是最顶层的元素,这个数据比较像省市县等多级分类的树状结构的数据,有些同学可能要问了...另外,需要注意的是当我们想要分类按照一定的顺序排列的时候,最好能够加上一个sort字段,根据sort的值降序排列分类项即可,若sort的值是一样的,则按照元素的id降序,这样就能保持一致的分类树输出了。

    39320

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

    无限级分类查询有很多方式。本文记录的方式是先将所有数据查出来,再使用递归对数据进行排序,并附加层级字段(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
    领券