[thinkphp] 无限极分类

<?php
        /*
        *     无限极分类 类
        */
    header("Content-Type: text/html; charset=UTF-8");
    Class Category {
        //组合一维数组
        Static Public function unlimitedForLevel ($cate, $html = ‘--‘, $pid = 0, $level = 0) {
            $arr = array();
            foreach ($cate as $k => $v) {
                if ($v[‘pid‘] == $pid) {
                    $v[‘level‘] = $level + 1;
                    $v[‘html‘]  = str_repeat($html, $level);
                    $arr[] = $v;
                    $arr = array_merge($arr, self::unlimitedForLevel($cate, $html, $v[‘id‘], $level + 1));
                }
            }
            return $arr;
        }
        //组合多维数组
        Static Public function unlimitedForLayer ($cate, $name = ‘child‘, $pid = 0) {
            $arr = array();
            foreach ($cate as $v) {
                if ($v[‘pid‘] == $pid) {
                    $v[$name] = self::unlimitedForLayer($cate, $name, $v[‘id‘]);
                    $arr[] = $v;
                }
            }
            return $arr;
        }
        //传递一个子分类ID返回所有的父级分类
        Static Public function getParents ($cate, $id) {
            $arr = array();
            foreach ($cate as $v) {
                if ($v[‘id‘] == $id) {
                    $arr[] = $v;
                    $arr = array_merge(self::getParents($cate, $v[‘pid‘]), $arr);
                }
            }
            return $arr;
        }
        //传递一个父级分类ID返回所有子分类ID
        Static Public function getChildsId ($cate, $pid) {
            $arr = array();
            foreach ($cate as $v) {
                if ($v[‘pid‘] == $pid) {
                    $arr[] = $v[‘id‘];
                    $arr = array_merge($arr, self::getChildsId($cate, $v[‘id‘]));
                }
            }
            return $arr;
        }
        //传递一个父级分类ID返回所有子分类
        Static Public function getChilds ($cate, $pid) {
            $arr = array();
            foreach ($cate as $v) {
                if ($v[‘pid‘] == $pid) {
                    $arr[] = $v;
                    $arr = array_merge($arr, self::getChilds($cate, $v[‘id‘]));
                }
            }
            return $arr;
        }

    }

$cate = array(
    0 => array(‘id‘ => 1, ‘pid‘ => 0, ‘name‘ => ‘江西省‘),
    1 => array(‘id‘ => 2, ‘pid‘ => 0, ‘name‘ => ‘浙江省‘),
    2 => array(‘id‘ => 3, ‘pid‘ => 1, ‘name‘ => ‘上饶市‘),
    3 => array(‘id‘ => 4, ‘pid‘ => 3, ‘name‘ => ‘广丰县‘),
    4 => array(‘id‘ => 5, ‘pid‘ => 2, ‘name‘ => ‘杭州市‘),
    5 => array(‘id‘ => 6, ‘pid‘ => 5, ‘name‘ => ‘西湖‘),
    6 => array(‘id‘ => 7, ‘pid‘ => 6, ‘name‘ => ‘断桥‘),
);
//print_r(Category::unlimitedForLevel($cate));
print_r(Category::unlimitedForLayer($cate));
//print_r(Category::getParents($cate,7));
//print_r(Category::getChildsId($cate,2));
//print_r(Category::getChilds($cate,2));
 ?>

转自:http://www.thinkphp.cn/topic/13132.html

时间: 2024-10-29 19:10:17

[thinkphp] 无限极分类的相关文章

thinkphp无限极分类

这里首先介绍一下,什么是无限极分类? 无限极分类简单点说就是将一个类分成多个子类,然后一个子类又可以分另外多个子类这样无限分下去,就好象windows可以新建一个文件夹,然后在这个文件夹里又可以建一些个文件夹,在文件夹底下还可以建一些文件夹一样 那用Thinkphp如何实现无限分类的呢? 下面看一下分类结果: 下面给出实例代码: 1.先创建Model文件并在里面定义两个方法,如下: <?php namespace app\admin\model; use think\Model; class C

thinkphp 无限极分类的数据库设计及效果测试

控制器继承IndexAction.class.php <?php // 本类由系统自动生成,仅供测试用途 class IndexAction extends CateAction { } ?> 控制器代码CateAction.class.php <?php class CateAction extends Action{ function index(){ $cate=M('Cate'); $list=$cate->field("id,name,pid,path,conc

夺命雷公狗ThinkPHP项目之----企业网站8之栏目的添加完善(无限极分类的完成)

我们刚才只是完成了添加的一部分,但是我们的上级分类也不能永远都是只有一个死的嘛,所以我们需要对她进行修改: 我们先将add方法里面的数据查出来再说: 然后在模板页进行遍历: 展示效果如下所示: 虽然是出现了,但是没有向我们平常时候见到的无限极分类一样噢,一般比如分类 多多,分类下面的 好多美女啊 是多多的下级分类,那么好多美女啊他前面是有几个空格之类的隔开, 那么我们就需要在model层里面对她进行排序的设置了: <?php namespace Admin\Model; use Think\Mo

php无限极分类以及递归(thinkphp)

php无限极分类: 无限极分类重点在于表的设计: 1在model中: class CatModel extends Model{ protected $cat = array(); public function __construct(){ parent::__construct(); $this->cats = $this->select(); } public function getTree($parent_id=0,$lev=0){ $tree = array(); foreach(

thinkphp5.0无限极分类及格式化输出

首先我们来看数据表 从上图中可以发现,中国下有贵州,北京两个子节点,而北京有天安门一个子节点,纽约的子节点是"纽约的子类". 从pid为0看出,中国和纽约是顶级节点. 因为贵州的pid是1,而中国的id为1,所以贵州的父节点是中国,至于type字段,可以不用管,只是我自己的项目需要. 可以发现,着写数据在数据表中是无序的,并没有我们想象中的层次结构分明并且可读性很好. 那么,当使用无限极分类之后数据的输出是怎样的呢?如下: 这样就能够很清晰的看出他们的层次结构了,那么这样的效果在thi

PHP无限极分类

概述 ??在实际工作中,经常要用到无限极分类.如导航表等等.到网上一搜php无限极分类,很多,但好多都是一个,并且,写的很乱,代码很多,那些都不靠谱,还是自己捣鼓捣鼓无限极分类了.下面介绍两种无限极分类:递归,使用引用 数据准备 //初始化原始数据(id=>编号,name=>显示名称,pid=>父级目录id,sort=>排序顺序) $data[1] = array('id'=>'1','name'=>'一级目录A','pid'=>'0','sort'=>'1

php递归无限极分类

递归无限级分类有几种形式,我这里只举例比较常用的三种: 第一种:返回有排序的数组: <?php $data = array( 1 => array( 'id' => 1, 'pid' => 0, 'user_name' => 'one', ), 2 => array( 'id' => 2, 'pid' => 1, 'user_name' => 'two', ), 3 => array( 'id' => 3, 'pid' => 1, '

递归与无限极分类

在函数内部调用本身,且在调用时要做判断. 例:输出1~9 function deeploop(&$i=1){   //引用传值,防止递归时从1开始 echo  $i; $i++; if($i < 10){             //条件判断,防止无限递归 deeploop($i); } } 2.无限极分类原理:每次分类都需要记录它的父级id,如果是顶级,则父级id为0,通过父级id,一层一层往下查. 首先从数据库中取出结果集,把结果集中的pid与顶级的pid开始,然后确定顶级父级.依次往下

C#无限极分类树-创建-排序-读取 用Asp.Net Core+EF实现之方法二:加入缓存机制

在上一篇文章中我用递归方法实现了管理菜单,在上一节我也提到要考虑用缓存,也算是学习一下.Net Core的缓存机制. 关于.Net Core的缓存,官方有三种实现: 1.In Memory Caching 我理解是在内容中实现,这种方法适用于单服务器的生产环境. 2.a Distributed Cache 分部式缓存实现. 3.Response Cache 这种方式我理解为客户端缓存. 今天我只用了第一种实现方法,内存中缓存,之所以用这种方法我是觉得我这里用缓存的初衷是为了减少访问数据库的次数,