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程序设计有所帮助。
热门推荐
5 修祖屋祝福语简短
7 怎么说祝福语简短
10 初八祝福语简短语
11 送去考试祝福语大全简短
12 对女友的简短祝福语
13 男士送花祝福语大全简短
14 双节祝福语简短唯美
15 动心的生日祝福语简短
16 婆婆生日祝福语简短的
17 下雪宝宝生日祝福语简短
18 朋友家住豪宅祝福语简短