A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

以上是效果图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="添加栏目" />


1 个回复

倒序浏览
奈斯,感谢分享
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马