以上是效果图
1.数据库设计
2.添加后数据库的数据如下图
解析下:cid 栏目自增id
pid 栏目的父类id,id为0表示是顶级栏目
cat_name 栏目名称
path 表示栏目的层级关系
实现效果主要用到:
mysql的一个函数 concat():返回结果为连接参数产生的字符串
1,控制器的分类显示方法
- publicfunctionfenlei(){ $cate=M('Category');
- $list=$cate->field("cid,cat_name,pid,path,concat(path,'-',cid)asbpath")->order('bpath')->select(); foreach($listas$key=>$value){
- $list[$key]['count']=count(explode('-',$value['bpath'])); }
- $this->assign('alist',$list); $this->display();
- }
2,控制器的分类添加方法
- publicfunctionaddCat(){ $cate=D('Category');
- if($cate->create()){ if($cate->add()){
- $this->redirect('/Test/fenlei'); }else{
- $this->error('添加栏目失败'); }
- }else{ $this->error($cate->getError());
- } }
3,栏目模型类
- protected$_auto=array( array('path','tclm',3,'callback'),
- ); functiontclm(){
- $pid=isset($_POST['pid'])?(int)$_POST['pid']:0; //echo($pid);
- if($pid==0){ $data=0;
- }else{ $list=$this->where("cid=$pid")->find();
- $data=$list['path'].'-'.$list['cid'];//子类的path为父类的path加上父类的cid }
- return$data; }
- } ?>
4,主要的html代码
请选择父类栏目: - {$v['cat_name']}
- 新的栏目名称: