商品分類遞歸刪除

商品分類遞迴刪除

#刪除我們之前也做過,但是又有些不同,分類的刪除更為複雜點,我們在刪除頂級欄目的時候應該連同頂級欄位下面的分類也一起刪除。

cate控制器

 public function del($id){
        $cata=D('cate');
        $childids=$cata->getchild($id);
        $childids=implode(',',$childids);
        if($cata->delete($childids)){
          $this->success('删除栏目成功!',U('index'));
        }else{
            $this->error('删除栏目失败!');
        }
    }

CateModel模型層

 public function getchild($cateid){
        $data=$this->select();
        return $this->getchildids($data,$cateid);
    }
    public function getchildids($data,$cateid){
        static $res=array();
        $res[]=$cateid;
        foreach ($data as $k => $v) {
            if ($v['pid']==$cateid) {
                    $res[]=$v['id'];
                    $this->getchildids($data,$v['id']);

            }
        }
        return array_unique($res);
    }

我們來分層次的來講解

$childids=$cata->getchild($id);

把id傳給getchild方法。

public function getchild($cateid){
        $data=$this->select();
        return $this->getchildids($data,$cateid);
    }

這裡getchild方法接受到傳來的id後查詢所有的分類。傳回資料和id到getchildids方法。

  public function getchildids($data,$cateid){
        static $res=array();
        $res[]=$cateid;
        foreach ($data as $k => $v) {
            if ($v['pid']==$cateid) {
                    $res[]=$v['id'];
                    $this->getchildids($data,$v['id']);

            }
        }
        return array_unique($res);
    }

$res=array();定義一個陣列。 $res[]=$cateid;空數組用來儲存id.

foreach 去遍歷數據,當他的pid等於當前id的時候說明是頂級,這時候吧id存入到$ res[]這個空數組中,再用遞歸呼叫。

return array_unique($res);是Eileen回傳這個陣列,array_unique去重。

$childids=implode(',',$childids);把陣列分割成字串就可以使用了。

這是刪除頂級欄位就能發現刪除的是多個了.

繼續學習
||
<?php namespace Admin\Controller; use Think\Controller; class CateController extends CommonController { public function index(){ $cate=D('cate'); $cateres=$cate->catetree(); $this->assign('cateres',$cateres);//获取栏目树 $this->display(); } public function add(){ $cate=D('cate'); if (IS_POST) { if($cate->create()){ if ($cate->add()) { $this->success('添加商品分类成功',U('Cate/add')); }else{ $this->error('添加商品分类失败!'); } }else{ $this->error($cate->getError()); } return; } $cateres=$cate->catetree(); $this->assign('cateres',$cateres); $this->display(); } public function edit(){ $cate=D('cate'); if (IS_POST) { if($cate->create()){ if ($cate->save()!== false) { $this->success('修改商品分类成功',U('Cate/index')); }else{ $this->error('修改商品分类失败!'); } }else{ $this->error($cate->getError()); } return; } $cates=$cate->find(I('id')); $cateres=$cate->catetree(); $this->assign('cateres',$cateres); $this->assign('cates',$cates); $this->display(); } public function del($id){ $cata=D('cate'); $childids=$cata->getchild($id); $childids=implode(',',$childids); if($cata->delete($childids)){ $this->success('删除栏目成功!',U('index')); }else{ $this->error('删除栏目失败!'); } } }