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(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。