Yii中CGridView实现批量删除的方法
本文实例讲述了Yii中CGridView实现批量删除的方法。分享给大家供大家参考,具体如下:
1.CGridView中的columns添加
array( 'selectableRows'=>2, 'footer'=>'<buttontype="button"onclick="GetCheckbox();"style="width:76px">批量删除</button>', 'class'=>'CCheckBoxColumn', 'headerHtmlOptions'=>array('width'=>'33px'), 'checkBoxHtmlOptions'=>array('name'=>'selectdel[]'), ),
作用是添加多选框
2.js代码
<scripttype="text/javascript"> /*<![CDATA[*/ varGetCheckbox=function(){ vardata=newArray(); $("input:checkbox[name='selectdel[]']").each(function(){ if($(this).attr("checked")==true){ data.push($(this).val()); } }); if(data.length>0){ $.post('<?phpechoCHtml::normalizeUrl(array('/admin/words/delall/'));?>',{'selectdel[]':data},function(data){ varret=$.parseJSON(data); if(ret!=null&&ret.success!=null&&ret.success){ $.fn.yiiGridView.update('yw1'); } }); }else{ alert("请选择要删除的关键字!"); } } /*]]>*/ </script>
3.Action
publicfunctionactionDelall() { if(Yii::app()->request->isPostRequest) { $criteria=newCDbCriteria; $criteria->addInCondition('id',$_POST['selectdel']); Words::model()->deleteAll($criteria);//Words换成你的模型 if(isset(Yii::app()->request->isAjaxRequest)){ echoCJSON::encode(array('success'=>true)); }else{ $this->redirect(isset($_POST['returnUrl'])?$_POST['returnUrl']:array('index')); } } else thrownewCHttpException(400,'Invalidrequest.Pleasedonotrepeatthisrequestagain.'); }
希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。