首頁 >後端開發 >php教程 >ThinkPHP實作批次刪除欄目的方法

ThinkPHP實作批次刪除欄目的方法

墨辰丷
墨辰丷原創
2018-05-21 11:39:191699瀏覽

本篇文章主要介紹ThinkPHP實作批次刪除欄目的方法,有興趣的朋友參考下,希望對大家有幫助。

我們需要達到的是這樣一個效果:

#勾選批次刪除按鈕後可以選取所有該頁面的欄目,這個是前端頁面的實現,在這裡就不多說了,我們直接進入正題:批量刪除的功能。

1.前端頁面這裡也有一個小小的點,就是選擇框的name值應給給他賦值為一個id的數組,value值為該欄目的id。

2.我們在控制器中單獨寫一個批次刪除的方法

#
public function privilege_bdel(){
  $ids = I('ids');
  $pri = D('privilege');
  $ids = implode(',', $ids);
  if($ids){
   if($pri->delete($ids)){
    $this->success('批量删除栏目成功!',U('Privilege/privilege_lst'));
   }else{
    $this->error('批量删除栏目失败,请重试!');
   }
  }else{
   $this->error('未选中任何内容,请重试!');
  }
 }

這裡要將傳過來的id數組轉換為以逗號分隔的字串如:1,2,3,這樣可以直接進行delete操作。

這就是我們dump出來options的結果,這條也是我們用來判斷刪除時是單一刪除還是批次刪除的依據,如果options[where][id]是一個陣列的話,則說明進行的是批次刪除,否則就是單一刪除。

3.在模型中對刪除前建構函式的修改

#
public function _before_delete($options){
  //批量删除
  if(is_array($options['where']['id'])){
   $arr = explode(',', $options['where']['id'][1]);
   $sonpri = array();
   foreach ($arr as $k => $v) {
    $sonpri2 = $this->childid($v);
    $sonpri = array_merge($sonpri,$sonpri2);
   }
   $sonpri = array_unique($sonpri);
   $chilrenids = implode(',', $sonpri);
  }else{//单个删除
   $chilrenids =$this->childid($options['where']['id']);
   $chilrenids = implode(',', $chilrenids);
  }
  if($chilrenids){
   $this->execute("delete from ed_privilege where id in($chilrenids)");
  }
 }

在這裡我們寫出批次刪除的程式碼(單一刪除之前已經寫過,不再提)##​​

#將傳過來的字串轉換為不帶逗號的陣列形式存在$arr中,建立一個空數組$sonpri,然後foreach遍歷,這裡先找出所有的子欄位id(會用childid函數),存入$sonpri2數組中,再將$sonpri和$sonpri2合併為一個數組,使用array_merge()函數完成,這樣我們才算是獲取到了所有子欄目的id,但是我們所取得的id組中,會出現許多重複的id,所以這裡我們還要進行去重的操作,使用array_unique()函數。最後再進行一次陣列的拆分,得到id字串,再進行刪除就大功告成了。

相關建議:

PHP實作批次刪除jQuery運算的方法

ThinkPH實作批次刪除欄位程式碼分享

PHP批次刪除jQuery實例程式碼

以上是ThinkPHP實作批次刪除欄目的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn