0

0

基于THINKPHP3.0无限级分类

php中文网

php中文网

发布时间:2016-06-07 11:45:40

|

1267人浏览过

|

来源于php中文网

原创

无限极分类在做项目中经常会用到,无限极分类的实现方法也多种实现形式,下面我分享一个基于thinkphp3.0的无极限分类,同时也支持普通传值的无极限分类。说明该类很久以前我在互联网上找到是,原编写者信息没有,这里我只是在原有的基础上做了些修改和格式化。
分类表需包含3个基本字段:cid,fid,name 即:分类cid,父级fid,分类名称。
表结构:CREATE TABLE `think_category` (
  `cid` int(11) NOT NULL AUTO_INCREMENT,
  `fid` int(11) DEFAULT NULL,
  `name` varchar(30) DEFAULT NULL
  PRIMARY KEY (`cid`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;
有两种使用方法:
第一种是基于THINKPHP3.0的使用:下载后将Category.class.php放到当前项目的ORG目录下(其他的目录也可只要能正常引用) import("@.ORG.Category");
$cat = new Category('Category', array('cid', 'fid', 'name', 'fullname'));
$s = $cat->getList();               //获取分类结构
$s = $cat->getList('', 1);          //获取fid=1的子分类结构
$s = $cat->getList($condition, 1);  //$condition为查询条件,获取fid=1的子分类结构
$s = $cat->getPath(3);              //获取分类id=3的路径
$data = array("fid" => 0, "name" => "新分类名称");
$s = $cat->add($data);              //添加分类,$data需要包含上级分类fid
$data = array("cid" => 2, "name" => "修改后分类名称");
$s = $cat->edit($data);             //修改分类,$data需要包含分类ID
$s = $cat->del(10);                 //删除分类id=10的分类
第二种使用方法不需要使用TP的支持,但是数据结构需一样。

分类类文件Category.class.php内容:
/**
  +------------------------------------------------------------------------------
 * 分类管理
  +------------------------------------------------------------------------------
 */
class Category {

    private $model;                                                           //分类的数据表模型
    private $rawList = array();                                              //原始的分类数据
    private $formatList = array();                                           //格式化后的分类
    private $error = "";                                                      //错误信息
    private $icon = array('  │', '  ├ ', '  └ ');  //格式化的字符
    private $fields = array();                                               //字段映射,分类id,上级分类fid,分类名称name,格式化后分类名称fullname

    /**
      +----------------------------------------------------------
     * 构造函数,对象初始化
      +----------------------------------------------------------
     * @param array,object  $model      数组或对象,基于TP3.0的数据表模型名称,若不采用TP,可传递空值。
     * @param array         $field      字段映射,分类cid,上级分类fid,分类名称,格式化后分类名称fullname
      +----------------------------------------------------------
     */

    public function __construct($model = '', $fields = array()) {
        if (is_string($model) && (!empty($model))) {
            if (!$this->model = D($model))
                $this->error = $model . "模型不存在!";
        }
        if (is_object($model))
            $this->model = &$model;

        $this->fields['cid'] = $fields['0'] ? $fields['0'] : 'cid';
        $this->fields['fid'] = $fields['1'] ? $fields['1'] : 'fid';
        $this->fields['name'] = $fields['2'] ? $fields['2'] : 'name';
        $this->fields['fullname'] = $fields['3'] ? $fields['3'] : 'fullname';
    }

    /**
      +----------------------------------------------------------
     * 获取分类信息数据
      +----------------------------------------------------------
     * @param array,string  $condition  查询条件
     * @param string        $orderby    排序
      +----------------------------------------------------------
     */
    private function _findAllCat($condition, $orderby = NULL) {
        $this->rawList = empty($orderby) ? $this->model->where($condition)->select() : $this->model->where($condition)->order($orderby)->select();
    }

    /**
      +----------------------------------------------------------
     * 返回给定上级分类$fid的所有同一级子分类
      +----------------------------------------------------------
     * @param   int     $fid    传入要查询的fid
      +----------------------------------------------------------
     * @return  array           返回结构信息
      +----------------------------------------------------------
     */
    public function getChild($fid) {
        $childs = array();
        foreach ($this->rawList as $Category) {
            if ($Category[$this->fields['fid']] == $fid)
                $childs[] = $Category;
        }
        return $childs;
    }

    /**
      +----------------------------------------------------------
     * 递归格式化分类前的字符
      +----------------------------------------------------------
     * @param   int     $cid    分类cid
     * @param   string  $space
      +----------------------------------------------------------
     */
    private function _searchList($cid = 0, $space = "") {
        $childs = $this->getChild($cid);
        //下级分类的数组
        //如果没下级分类,结束递归
        if (!($n = count($childs)))
            return;
        $m = 1;
        //循环所有的下级分类
        for ($i = 0; $i              $pre = "";
            $pad = "";
            if ($n == $m) {
                $pre = $this->icon[2];
            } else {
                $pre = $this->icon[1];
                $pad = $space ? $this->icon[0] : "";
            }
            $childs[$i][$this->fields['fullname']] = ($space ? $space . $pre : "") . $childs[$i][$this->fields['name']];
            $this->formatList[] = $childs[$i];
            $this->_searchList($childs[$i][$this->fields['cid']], $space . $pad . "  "); //递归下一级分类
            $m++;
        }
    }

    /**
      +----------------------------------------------------------
     * 不采用数据模型时,可以从外部传递数据,得到递归格式化分类
      +----------------------------------------------------------
     * @param   array,string     $condition    条件
     * @param   int              $cid          起始分类
     * @param   string           $orderby      排序
      +----------------------------------------------------------
     * @return  array           返回结构信息
      +----------------------------------------------------------
     */
    public function getList($condition = NULL, $cid = 0, $orderby = NULL) {
        unset($this->rawList, $this->formatList);
        $this->_findAllCat($condition, $orderby, $orderby);
        $this->_searchList($cid);
        return $this->formatList;
    }

    /**
      +----------------------------------------------------------
     * 获取结构
      +----------------------------------------------------------
     * @param   array            $data         二维数组数据
     * @param   int              $cid          起始分类
      +----------------------------------------------------------
     * @return  array           递归格式化分类数组
      +----------------------------------------------------------
     */
    public function getTree($data, $cid = 0) {
        unset($this->rawList, $this->formatList);
        $this->rawList = $data;
        $this->_searchList($cid);
        return $this->formatList;
    }

    /**
      +----------------------------------------------------------
     * 获取错误信息
      +----------------------------------------------------------
     * @return  string           错误信息字符串
      +----------------------------------------------------------
     */
    public function getError() {
        return $this->error;
    }

    /**
      +----------------------------------------------------------
     * 检查分类参数$cid,是否为空
      +----------------------------------------------------------
     * @param   int              $cid          起始分类
      +----------------------------------------------------------
     * @return  boolean           递归格式化分类数组
      +----------------------------------------------------------
     */
    private function _checkCatID($cid) {
        if (intval($cid)) {
            return true;
        } else {
            $this->error = "参数分类ID为空或者无效!";
            return false;
        }
    }

    /**
      +----------------------------------------------------------
     * 检查分类参数$cid,是否为空
      +----------------------------------------------------------
     * @param   int         $cid        分类cid
      +----------------------------------------------------------
     */
    private function _searchPath($cid) {
        //检查参数
        if (!$this->_checkCatID($cid))
            return false;
        $rs = $this->model->find($cid);                                        //初始化对象,查找上级Id;
        $this->formatList[] = $rs;                                            //保存结果
        $this->_searchPath($rs[$this->fields['fid']]);
    }

    /**
      +----------------------------------------------------------
     * 查询给定分类cid的路径
      +----------------------------------------------------------
     * @param   int         $cid        分类cid
      +----------------------------------------------------------
     * @return  array                   数组
      +----------------------------------------------------------
     */
    public function getPath($cid) {
        unset($this->rawList, $this->formatList);
        $this->_searchPath($cid);                                               //查询分类路径
        return array_reverse($this->formatList);
    }

    /**
      +----------------------------------------------------------
     * 添加分类
      +----------------------------------------------------------
     * @param   array         $data        一维数组,要添加的数据,$data需要包含上级分类ID。
      +----------------------------------------------------------
     * @return  boolean                    添加成功,返回相应的分类ID,添加失败,返回FALSE;
      +----------------------------------------------------------
     */
    public function add($data) {
        if (empty($data))
            return false;
        return $this->model->data($data)->add();
    }

    /**
      +----------------------------------------------------------
     * 修改分类
      +----------------------------------------------------------
     * @param   array         $data     一维数组,$data需要包含要修改的分类cid。
      +----------------------------------------------------------
     * @return  boolean                 组修改成功,返回相应的分类ID,修改失败,返回FALSE;
      +----------------------------------------------------------
     */
    public function edit($data) {
        if (empty($data))
            return false;
        return $this->model->data($data)->save();
    }

    /**
      +----------------------------------------------------------
     * 删除分类
      +----------------------------------------------------------
     * @param   int         $cid        分类cid
      +----------------------------------------------------------
     * @return  boolean                 删除成功,返回相应的分类ID,删除失败,返回FALSE
      +----------------------------------------------------------
     */
    public function del($cid) {
        $cid = intval($cid);
        if (empty($cid))
            return false;
        $conditon[$this->fields['cid']] = $cid;
        return $this->model->where($conditon)->delete();
    }

}
?>
这个编辑器太不给力了,编辑框又这么小,详细的使用方法和测试包去我的blog下载吧,http://blog.51edm.org/post/78

AD:真正免费,域名+虚机+企业邮箱=0元

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

4

2026.01.16

全民K歌得高分教程大全
全民K歌得高分教程大全

本专题整合了全民K歌得高分技巧汇总,阅读专题下面的文章了解更多详细内容。

3

2026.01.16

C++ 单元测试与代码质量保障
C++ 单元测试与代码质量保障

本专题系统讲解 C++ 在单元测试与代码质量保障方面的实战方法,包括测试驱动开发理念、Google Test/Google Mock 的使用、测试用例设计、边界条件验证、持续集成中的自动化测试流程,以及常见代码质量问题的发现与修复。通过工程化示例,帮助开发者建立 可测试、可维护、高质量的 C++ 项目体系。

10

2026.01.16

java数据库连接教程大全
java数据库连接教程大全

本专题整合了java数据库连接相关教程,阅读专题下面的文章了解更多详细内容。

33

2026.01.15

Java音频处理教程汇总
Java音频处理教程汇总

本专题整合了java音频处理教程大全,阅读专题下面的文章了解更多详细内容。

15

2026.01.15

windows查看wifi密码教程大全
windows查看wifi密码教程大全

本专题整合了windows查看wifi密码教程大全,阅读专题下面的文章了解更多详细内容。

42

2026.01.15

浏览器缓存清理方法汇总
浏览器缓存清理方法汇总

本专题整合了浏览器缓存清理教程汇总,阅读专题下面的文章了解更多详细内容。

7

2026.01.15

ps图片相关教程汇总
ps图片相关教程汇总

本专题整合了ps图片设置相关教程合集,阅读专题下面的文章了解更多详细内容。

9

2026.01.15

ppt一键生成相关合集
ppt一键生成相关合集

本专题整合了ppt一键生成相关教程汇总,阅读专题下面的的文章了解更多详细内容。

6

2026.01.15

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Git 教程
Git 教程

共21课时 | 2.7万人学习

Kotlin 教程
Kotlin 教程

共23课时 | 2.6万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号