thinkphp实现无限分类

157 阅读1分钟
以上是效果图1.数据库设计2.添加后数据库的数据如下图解析下:cid栏目自增idpid栏目的父类id,id为0表示是顶级栏目cat_name栏目名称p...


以上是效果图
1.数据库设计
2.添加后数据库的数据如下图
解析下:cid 栏目自增id
pid 栏目的父类id,id为0表示是顶级栏目
cat_name 栏目名称
path 表示栏目的层级关系
实现效果主要用到:
mysql的一个函数 concat():返回结果为连接参数产生的字符串
1,控制器的分类显示方法
  • public function fenlei (){
  • $cate=M('Category');
  • $list=$cate->field("cid,cat_name,pid,path,concat(path,'-',cid) as bpath")->order('bpath')->select();
  • foreach($list as $key=>$value){
  • $list[$key]['count']=count(explode('-',$value['bpath']));
  • }
  • $this->assign('alist',$list);
  • $this->display();
  • }
2,控制器的分类添加方法
  • public function addCat(){
  • $cate=D('Category');
  • if($cate->create()){
  • if($cate->add()){
  • $this->redirect('/Test/fenlei');
  • }else{
  • $this->error('添加栏目失败');
  • }
  • }else{
  • $this->error($cate->getError());
  • }
  • }
3,栏目模型类
  • class CategoryModel extends Model{
  • protected $_auto=array(
  • array('path','tclm',3,'callback'),
  • );
  • function tclm(){
  • $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代码
  • <form action="__URL__/addCat"</form action= method="post" >
  • "text-align:center;margin-top:80px;"</div style= >
  • 请选择父类栏目:<select name="pid"</select name= size="20" style="width:250px;">
  • <volist name="alist"</volist name= id="v" >
  • <option value="{$v['cid']}"</option value= >
  • <for start="0" end="$v['count']">
  • for>
  • {$v['cat_name']}
  • 新的栏目名称:<input type="text"</input type= name="cat_name" style="width:230px;" />
  • <input type="submit"</input type= value="添加栏目" />