yii 全选 php,yii2中gridview使用技巧小结(四)——全选等批量操作
在用gridview時,大家都注意到了,列表的開頭有現成的復選框,這肯定是批量操作中用到的,今天就來介紹一下,gridview中的批量操作,簡直簡單的不行,效果圖如下:
前端頁面只需要改這幾個地方即可,
1、gridview設置options時增加一個id 這里我們命名grid。
2.columns增加選項復選框,批量刪除必然不可少了復選框操作,這里我們的name值設定為id,方便對數據操作,代碼如下'options'?=>['id'=>'grid'],
'columns'?=>?[
[
'class'?=>?'yii\grid\CheckboxColumn',
'name'=>'id',
],//復選框列
3、頁面上我們增加一個批量刪除按鈕,注意這里我們增加了一個class gridviewdelete,方便后面js實現點擊效果=?Html::a('批量刪除',?"javascript:void(0);",?['class'?=>?'btn?btn-primary?gridviewdelete'])??>
4、最后一步,寫js實現按鈕操作,我們很輕松的就拿到了選中的行的id,然后這里就可以異步操作數據了。$script?=?<<
if(confirm('您確定要刪除嗎?')){
var?keys?=?$("#grid").yiiGridView("getSelectedRows");
$.ajax({
url:?'/food/batchdelete',
data:?{ids:keys},
type:?'post',
success:?function?(t)?{
t?=?JSON.parse(t);
if?(t.status?==?1)?{
window.location.href=?window.location.href;
}
},
error:?function?()?{
alert("刪除失敗!")
}
})
}
});
SCRIPT;
$this->registerJs($script);
?>
5.post傳給控制器的是一個數組,這里我寫了一個批量操作的方法,一塊貼出來,這里的刪除為邏輯刪除public?function?actionBatchdelete(){
$this->enableCsrfValidation?=?false;//去掉yii2的post驗證
$ids?=?Yii::$app->request->post();
$model?=?new?Product();
if($model->batchHandle($ids['ids']))
return?\yii\helpers\Json::encode(['status'=>1,'info'=>'刪除成功!']);
else
return?false;
}
其中batchHandle為批量操作的方法:public?function?batchHandle($ids?=?[],$status?=?3){
foreach?($ids?as?$k=>$v){
$model?=?$this->has(['id'=>$v]);
$model->status?=?$status;
if(!$model->save(false))
return?new?BadRequestHttpException('操作失敗!');
}
return?true;
}
//其中has方法如下:
public?function?has($where=[],?$field='*')?{
$result?=?$this->_query
->select($field)
->where($where)
->one();
return?empty($result)???false?:?$result;
}
批量操作就這樣完成了,是不是很簡單,gridview中的一些使用方法也算是總結的差不多了,希望能幫助到大家!該睡覺了!
總結
以上是生活随笔為你收集整理的yii 全选 php,yii2中gridview使用技巧小结(四)——全选等批量操作的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: php 常量 循环 1,php循环控制b
- 下一篇: php 上万关键字匹配,JavaScri