以上是效果圖
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,欄目模型類
- <?php
- 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代碼
- <body>
- <form action="__URL__/addCat" method="post" >
- <div style="text-align:center;margin-top:80px;" >
- 請選擇父類欄目:<select name="pid" size="20" style="width:250px;">
- <volist name="alist" id="v" >
- <option value="{$v['cid']}" >
- <for start="0" end="$v['count']">
-
- </for>
- {$v['cat_name']}
- </option>
- </volist>
- </select>
- <br/>
- 新的欄目名稱:<input type="text" name="cat_name" style="width:230px;" /><br/>
- <input type="submit" value="添加欄目" />
- </div>
- </form>
- </body>
新聞熱點
疑難解答
圖片精選