作者:美好生活的日子 | 来源:互联网 | 2014-06-12 18:37
以上是效果图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;
-
- if($pid==0){
- $data=0;
- }else{
- $list=$this->where("cid=$pid")->find();
- $data=$list['path'].'-'.$list['cid'];
- }
- return $data;
- }
- }
- ?>
4,主要的html代码
-
- "__URL__/addCat" method="post" >
"text-align:center;margin-top:80px;" >
- 请选择父类栏目: size="20" style="width:250px;">
- "alist" id="v" >
- >
- <for start="0" end="$v[&#39;count&#39;]">
-
- for>
- {$v[&#39;cat_name&#39;]}
-
-
-
- 新的栏目名称:"text" name="cat_name" style="width:230px;" />
- "submit" value="添加栏目" />
-
-