当前位置 : 主页 > 网络编程 > PHP >

THINKPHP3.2.3含有树形结构的无限分类的实现

来源:互联网 收集:自由互联 发布时间:2021-07-03
THINKPHP3.2.3含有树形结构的无限分类的实现,详细教程请访问http://gouguoyin.cn/php/6.html 1. [图片] 54fff0125903b.png 2. [代码] Category.class.php代码 ?phpnamespace Common\Helper;class Category { //一维数组 sta
THINKPHP3.2.3含有树形结构的无限分类的实现,详细教程请访问http://gouguoyin.cn/php/6.html

1. [图片] 54fff0125903b.png    

2. [代码]Category.class.php代码    

<?php
namespace Common\Helper;

class Category {

    //一维数组
    static public function toLevel($cate, $delimiter = '———', $parent_id = 0, $level = 0) {

        $arr = array();
        foreach ($cate as $v) {
            if ($v['parent_id'] == $parent_id) {
                $v['level'] = $level + 1;
                $v['delimiter'] = str_repeat($delimiter, $level);
                $arr[] = $v;
                $arr = array_merge($arr, self::toLevel($cate, $delimiter, $v['id'], $v['level']));
            }
        }

        return $arr;

    }


    //组成多维数组
    static public function toLayer($cate, $name = 'child', $pid = 0){

        $arr = array();
        foreach ($cate as $v) {
            if ($v['pid'] == $pid) {
                $v[$name] = self::toLayer($cate, $name, $v['id']);
                $arr[] = $v;
            }
        }

        return $arr;
    }


    //一维数组(同模型)(model = tablename相同),删除其他模型的分类
    static public function getLevelOfModel($cate, $tablename = 'article') {

        $arr = array();
        foreach ($cate as $v) {
            if ($v['tablename'] == $tablename) {
                $arr[] = $v;
            }
        }

        return $arr;

    }

    //一维数组(同模型)(modelid),删除其他模型的分类
    static public function getLevelOfModelId($cate, $modelid = 0) {

        $arr = array();
        foreach ($cate as $v) {
            if ($v['modelid'] == $modelid) {
                $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返回他的同级分类
    static public function getSameCate($cate, $id) {
        $arr = array();
        $self = self::getSelf($cate, $id);
        if (empty($self)) {
            return $arr;
        }

        foreach ($cate as $v) {
            if ($v['id'] == $self['pid']) {
                $arr[] = $v;
            }
        }
        return $arr;
    }



    //判断分类是否有子分类,返回false,true
    static public function hasChild($cate, $id) {
        $arr = false;
        foreach ($cate as $v) {
            if ($v['pid'] == $id) {
                $arr = true;
                return $arr;
            }
        }

        return $arr;
    }

    //传递一个父级分类ID返回所有子分类ID
    /**
    *@param $cate 全部分类数组
    *@param $pid 父级ID
    *@param $flag 是否包括父级自己的ID,默认不包括
    **/
    static public function getChildsId($cate, $pid, $flag = 0) {
        $arr = array();
        if ($flag) {
            $arr[] = $pid;
        }
        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;
    }

    //传递一个分类ID返回该分类相当信息
    static public function getSelf($cate, $id) {
        $arr = array();
        foreach ($cate as $v) {
            if ($v['id'] == $id) {
                $arr = $v;
                return $arr;
            }
        }
        return $arr;
    }

    //传递一个分类ID返回该分类相当信息
    static public function getSelfByEName($cate, $ename) {
        $arr = array();
        foreach ($cate as $v) {
            if ($v['ename'] == $ename) {
                $arr = $v;
                return $arr;
            }
        }
        return $arr;
    }

}

?>

3. [代码]控制器CategoryController.class    

<?php
/**
 * alltosun.com  CategoryController.class.php
 * ============================================================================
 * 版权所有 (C) 2014-2016 GoCMS内容管理系统
 * 官方网站:   http://www.gouguoyin.cn
 * 联系方式:   QQ:245629560
 * ----------------------------------------------------------------------------
 * 许可声明:这是一个开源程序,未经许可不得将本软件的整体或任何部分用于商业用途及再发布。
 * ============================================================================
 * $Author: 勾国印 (phper@gouguoyin.cn) $
 * $Date: 2015-3-11 下午4:00:17 $
 * $Id$
*/
namespace Admin\Controller;
use Think\Controller;
use Common\Helper\Category;
class CategoryController extends AuthController {
    //栏目列表页
    public function index(){
        $category_list = M('category')->order('sort desc')->select();
        $category_list = Category::toLevel($category_list, '&nbsp;&nbsp;&nbsp;&nbsp;',0);

    	$this->assign('category_list', $category_list);
    	$this->display('category_list');
    }

    //增加 栏目页面
    public function add(){
        $parent_id = I('parent_id', 0);

        $parent_category_info = M('Category')->where(array('id' => $parent_id))->find();

        if($parent_category_info){
            $this->assign('parent_id', $parent_id);
            $this->assign('parent_category_info', $parent_category_info);
        }


        $model_list = M('Model')->where(array('status' => 1))->order('sort asc')->select();

        $category_list = M('category')->order('sort desc')->select();
        $category_list = Category::toLevel($category_list, '---',0);

        $this->assign('category_list', $category_list);
        $this->assign('action', 'add');
        $this->assign('model_list', $model_list);
        $this->display('category_add');
    }


    //修改栏目
    public function edit(){
        $category_id = I('id');
        $category_info = M('Category')->find($category_id);
        $model_list = M('Model')->order('sort desc')->select();

        $category_list = M('category')->order('sort desc')->select();
        $category_list = Category::toLevel($category_list, '---',0);

        $this->assign('category_list', $category_list);
        $this->assign('action', 'edit');
        $this->assign('category_id', $category_id);
        $this->assign('category_info', $category_info);
        $this->assign('model_list', $model_list);

        $this->display('category_add');
    }

    //保存栏目
    public function save(){
        $Category = D("Category");
        if (!$Category->create()){
            //验证没有通过 输出错误提示信息
            $errormsg = $Category->getError();
            $this->error($errormsg);
        }else{
            // 验证通过进行其他数据操作
            $id       = I('id', 0);

            $data['title']    = I('title', '');
            $data['flag']     = I('flag', '');
            $data['parent_id']     = I('parent_id', 0);
            $data['content']  = I('content', '');
            $data['sort']     = I('sort', 0);
            $data['status']   = I('status', 1);
            $data['is_show']  = I('is_show', 1);
            $data['has_cover']  = I('has_cover', 1);
            $data['cover']  = I('cover', '');

            $category_info = $Category->find($id);
            if($category_info){
            	//更新操作
                $data['update_time'] = time();

                $result = $Category->where(array('id' => $id))->save($data);
                if(false !== $result || 0 !== $result){
                    $this->success('栏目更新成功', U('Admin/Category/index'));
                }else{
                    $this->error('栏目更新失败');
                }
            }else{
                $data['model_id']   = I('model_id', 0);
                $data['model_flag'] = M('Model')->where(array('id' => I('model_id')))->getField('flag');
                $data['add_time']   = time();

                //print_r($data);exit;

                $result = $Category->add($data);
                if($result){
                    $this->success('栏目添加成功', U('Admin/Category/index'));
                }else{
                    $this->error('栏目添加失败');
                }
            }
        }
    }

    //更新状态
    public function change_status()
    {
        $id = I('id');

        $Category = M('Category');
        $category_info = $Category->find($id);
        if(!$category_info){
            $this->ajaxReturn(array('info' => '该栏目不存在'));
        }else{
            if($category_info['status']){
                $status = 0;
            }else{
                $status = 1;
            }
            $result = $Category->where(array('id' => $id))->setField('status',$status);
            if(false != $result){
                $this->ajaxReturn(array('status' => 'ok', 'info' => '栏目状态更新成功'));
            }else{
                $this->ajaxReturn(array('info' => '栏目状态更新失败'));
            }
        }

    }

    //保存排序
    public function save_sort()
    {
        $id   = I('id');
        $sort = I('sort');

        $Category = M('Category');
        $result = $Category->where(array('id' => $id))->setField('sort',$sort);
        if(false !== $result || 0 !== $result){
            $this->ajaxReturn(array('status' => 'ok', 'info' => '排序更新成功'));
        }else{
            $this->ajaxReturn(array('info' => '排序更新失败'));
        }
    }

    //删除栏目
    public function delete()
    {
        $id = I('id');

        $Category = M('Category');
        $category_info = $Category->find($id);
        if(!$category_info){
            return array('info' => '该模型不存在');
        }else if($category_info['is_system']){
            return array('info' => '系统模型不允许删除');
        }else{
            $result = $Category->delete($id);
            if($result){
                $this->ajaxReturn(array('status' => 'ok', 'info' => '栏目删除成功'));
            }else{
                $this->ajaxReturn(array('info' => '栏目删除失败'));
            }
        }
    }

}

4. [代码]前端调用    

<div class="control-group ">
            <label>所属栏目:</label>
            <select name="pid">
                    <option value="0" {if condition="$category_info['parent_id'] eq 0"}selected{/if}>顶级栏目</option>
                    {foreach name='category_list' item='v'}
                    <option value="{$v.id}" {if condition="($parent_id eq $v['id']) OR ($category_id eq $v['id']) AND ($category_info['parent_id'] neq 0)"}selected{/if}>{$v.delimiter}{$v.title}</option>
                    {/foreach}
                </select>
                <span class="Validform_checktip"></span>
        </div>

5. [代码]数据库    

CREATE TABLE IF NOT EXISTS `go_category` (
  `id` int(10) NOT NULL AUTO_INCREMENT COMMENT '分类id',
  `model_id` int(10) NOT NULL COMMENT '模型id',
  `model_flag` varchar(20) NOT NULL COMMENT '模型标示符',
  `title` varchar(45) NOT NULL COMMENT '分类名称',
  `flag` varchar(255) NOT NULL COMMENT '栏目标示符,必须为字母或数字',
  `content` mediumtext NOT NULL COMMENT '内容,仅用于单页内容',
  `has_cover` tinyint(1) NOT NULL DEFAULT '0' COMMENT '是否开启封面',
  `cover` varchar(255) NOT NULL COMMENT '分类封面图',
  `parent_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '父级id',
  `sort` int(3) unsigned NOT NULL DEFAULT '0' COMMENT '显示顺序',
  `is_show` tinyint(1) NOT NULL DEFAULT '1' COMMENT '是否显示,1:显示,0:不显示,默认1',
  `status` tinyint(1) unsigned NOT NULL DEFAULT '1' COMMENT '状态',
  `add_time` datetime NOT NULL COMMENT '添加时间',
  `update_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  PRIMARY KEY (`id`),
  UNIQUE KEY `flag` (`flag`) COMMENT '标示符'
) ENGINE=MyISAM  DEFAULT CHARSET=utf8 COMMENT='栏目表' AUTO_INCREMENT=12 ;
网友评论