PHP实现的无限分类类库定义与用法示例【基于thinkPHP】
本文实例讲述了PHP实现的无限分类类库定义与用法。分享给大家供大家参考,具体如下:
/* 功能:基于TP2.0的无限分类。 用法: 第一种用法,不采用数据库,可以不需要TP,例子如下 1,'pid'=>0,'name'=>'中国'); $data[]=array('cat_id'=>2,'pid'=>0,'name'=>'美国'); $data[]=array('cat_id'=>3,'pid'=>0,'name'=>'韩国'); $data[]=array('cat_id'=>4,'pid'=>1,'name'=>'北京'); $data[]=array('cat_id'=>5,'pid'=>1,'name'=>'上海'); $data[]=array('cat_id'=>6,'pid'=>1,'name'=>'广西'); $data[]=array('cat_id'=>7,'pid'=>6,'name'=>'桂林'); $data[]=array('cat_id'=>8,'pid'=>6,'name'=>'南宁'); $data[]=array('cat_id'=>9,'pid'=>6,'name'=>'柳州'); $data[]=array('cat_id'=>10,'pid'=>2,'name'=>'纽约'); $data[]=array('cat_id'=>11,'pid'=>2,'name'=>'华盛顿'); $data[]=array('cat_id'=>12,'pid'=>3,'name'=>'首尔'); $cat=newCategory('',array('cat_id','pid','name','cname')); $s=$cat->getTree($data);//获取分类数据树结构 //$s=$cat->getTree($data,1);获取pid=1所有子类数据树结构 foreach($sas$vo) { echo$vo['cname'].'
'; } 第二种用法,采用数据库,基于TP,例子如下 数据表,前缀_articlec_cat,包含cat_id,pid,title三个字段 require('Category.class.php');//导入Category.class.php类 $cat=newCategory('ArticleCat',array('cat_id','pid','title','fulltitle')); $s=$cat->getList();//获取分类结构 $s=$cat->getList('',1);//获取pid=1的子分类结构 $s=$cat->getList($condition,1);//$condition为查询条件,获取pid=1的子分类结构 $s=$cat->getPath(3);//获取分类id=3的路径 $s=$cat->add($data);//添加分类,$data需要包含上级分类pid $s=$cat->edit($data);//修改分类,$data需要包含分类ID $s=$cat->del(10);//删除分类id=10的分类 详细用法:参考代码说明 /** +------------------------------------------------------------------------------ *分类管理 +------------------------------------------------------------------------------ */ classCategory { //分类的数据表模型 private$model; //原始的分类数据 private$rawList=array(); //格式化后的分类 private$formatList=array(); //错误信息 private$error=""; //格式化的字符 private$icon=array('│','├','└'); //字段映射,分类id,上级分类pid,分类名称title,格式化后分类名称fulltitle private$field=array(); /* 功能:构造函数,对象初始化; 属性:public; 参数:$model,数组或对象,基于TP2.0的数据表模型名称,若不采用TP2.0,可传递空值。 $field,字段映射,分类id,上级分类pid,分类名称title,格式化后分类名称fulltitle 依次传递,例如在分类数据表中,分类id,字段名为CatID,上级分类pid,字段名称name,希望格式化分类后输出cname, 则,传递参数为,$field('CatID','pid','name','cname');若为空,则采用默认值。 返回:无 备注:用到了TP的D函数 */ publicfunction__construct($model='',$field=array()) { //判断参数类型 if(is_string($model)&&(!empty($model))){ if(!$this->model=D($model))//注意这里的D函数需要TP支持 $this->error=$model."模型不存在!"; } if(is_object($model)){ $this->model=&$model; } $this->field['id']=$field['0']?$field['0']:'id'; $this->field['pid']=$field['1']?$field['1']:'pid'; $this->field['title']=$field['2']?$field['2']:'title'; $this->field['fulltitle']=$field['3']?$field['3']:'fulltitle'; } /* 功能:获取分类信息数据; 属性:private; 参数:查询条件$condition; 返回:无; 备注:需要TP支持 */ privatefunction_findAllCat($condition,$orderby=NULL) { if(empty($orderby)){ $this->rawList=$this->model->where($condition)->findAll(); }else{ $this->rawList=$this->model->where($condition)->order($orderby)->findAll(); } } /* 功能:返回给定上级分类$pid的所有同一级子分类; 属性:public; 参数:上级分类$pid; 返回:子分类,二维数组; 备注: */ publicfunctiongetChild($pid) { $childs=array(); foreach($this->rawListas$Category){ if($Category[$this->field['pid']]==$pid) $childs[]=$Category; } return$childs; } /* 功能:无限分类核心部分,递归格式化分类前的字符; 属性:private; 参数:分类id,前导空格; 返回:无; 备注: */ privatefunction_searchList($CatID=0,$space="") { //下级分类的数组 $childs=$this->getChild($CatID); //如果没下级分类,结束递归 if(!($n=count($childs))) return; $cnt=1; //循环所有的下级分类 for($i=0;$i<$n;$i++){ $pre=""; $pad=""; if($n==$cnt){ $pre=$this->icon[2]; }else{ $pre=$this->icon[1]; $pad=$space?$this->icon[0]:""; } $childs[$i][$this->field['fulltitle']]=($space?$space.$pre:"").$childs[$i][$this->field['title']]; $this->formatList[]=$childs[$i]; //递归下一级分类 $this->_searchList($childs[$i][$this->field['id']],$space.$pad.""); $cnt++; } } /* 功能:不采用数据模型时,可以从外部传递数据,得到递归格式化分类; 属性:public; 参数:$condition,数字或字符串,需要符合TP查询条件规则,起始分类id,$CatID=0; $orderby排序参数 返回:递归格式化分类数组; 备注:需要TP支持 */ publicfunctiongetList($condition=NULL,$CatID=0,$orderby=NULL) { unset($this->rawList); unset($this->formatList); $this->_findAllCat($condition,$orderby,$orderby); $this->_searchList($CatID); return$this->formatList; } /* 功能:不采用数据模型时,可以从外部传递数据,得到递归格式化分类; 属性:public; 参数:$data,二维数组,起始分类id,默认$CatID=0; 返回:递归格式化分类数组; 备注: */ publicfunctiongetTree($data,$CatID=0) { unset($this->rawList); unset($this->formatList); $this->rawList=$data; $this->_searchList($CatID); return$this->formatList; } /* 功能:获取错误信息; 属性:public; 参数:无; 返回:错误信息字符串; 备注: */ publicfunctiongetError() { return$this->error; } /* 功能:检查分类参数$CatID,是否为空; 属性:private; 参数:分类参数$CatID,整型。 返回:正确,返回true,错误,返回false; 备注: */ privatefunction_checkCatID($CatID) { if(intval($CatID)){ returntrue; }else{ $this->error="参数分类ID为空或者无效!"; returnfalse; } } /* 功能:查询路径; 属性:private; 参数:分类参数$CatID,整型。 返回:出错返回false; 备注:需要TP支持 */ privatefunction_searchPath($CatID) { //检查参数 if(!$this->_checkCatID($CatID)) returnfalse; //初始化对象,查找上级Id; $rs=$this->model->find($CatID); //保存结果 $this->formatList[]=$rs; $this->_searchPath($rs[$this->field['pid']]); } /* 功能:查询给定分类id的路径; 属性:public; 参数:分类参数$CatID,整型。 返回:数组; 备注:需要TP支持 */ publicfunctiongetPath($CatID) { unset($this->rawList); unset($this->formatList); //查询分类路径 $this->_searchPath($CatID); returnarray_reverse($this->formatList); } /****************************************以下为分类添加、修改、删除****************************************************/ /* 功能:添加分类; 属性:public; 参数:$data,一维数组,要添加的数据,$data需要包含上级分类ID。 返回:添加成功,返回相应的分类ID,添加失败,返回FALSE; 备注:需要TP支持 */ publicfunctionadd($data) { if(empty($data)) returnfalse; return$this->model->data($data)->add(); } /* 功能:修改分类; 属性:public; 参数:$data,一维数组,传递编辑的数据,$data需要包含要修改的分类ID。 返回:修改成功,返回相应的分类ID,修改失败,返回FALSE; 备注:需要TP支持 */ publicfunctionedit($data) { if(empty($data)) returnfalse; return$this->model->data($data)->save(); } /* 功能:删除分类; 属性:public; 参数:分类ID 返回:删除成功,返回相应的分类ID,删除失败,返回FALSE; 备注:需要TP支持 */ publicfunctiondel($CatID) { $CatID=intval($CatID); if(empty($CatID)) returnfalse; $conditon[$this->field['id']]=$CatID; return$this->model->where($conditon)->delete(); } }
更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP数据结构与算法教程》、《php程序设计算法总结》、《PHP常用遍历算法与技巧总结》、《PHP数学运算技巧总结》、《PHP数组(Array)操作技巧大全》、《php字符串(string)用法总结》及《php常见数据库操作技巧汇总》
希望本文所述对大家PHP程序设计有所帮助。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。