MyGridView::widget 列表显示
首先设置批量操作的名称 如:
<span class="btn btn-success pull-left" id="ratify" style="margin-right: 10px">
批量开通
</span>
在MyGridView::widget 列表中 添加多选框: 视图为aa.php
echo MyGridView::widget([
'dataProvider' => $dataProvider,
'id'=>'w1',
'columns' => [
[
'class' => CheckboxColumn::class,
'headerOptions' => [
'width' => '50',
]
],
])
js 引入外部jq
<script>
<?php $this->beginBlock('footerJs') ?>
function ratify(ids, type,level) {
$.ajax({
url: '<?= Url::toRoute([***])?>',
method: 'POST',
data: {ids: ids,type:type},
success: function (res) {
layer.closeAll();
if (res.code === 0) {
layer.msg(res.msg, {icon: 1, time: 1000}, function () {
history.go(0);
layer.reload();
});
}
else {
layer.msg(res.msg, {icon: 2, time: 2000});
}
},
error: function () {
layer.closeAll();
layer.msg('请求失败!', {icon: 2, time: 2000});
}
})
}
//批量通过
$("#ratify").click(function () {
layer.confirm('确定批量通过?', {icon: 3, title: '提示'}, function () {
layer.load();
var ids = $('#w1').yiiGridView('getSelectedRows');
if (ids.length==0){
layer.closeAll();
layer.msg('请选择要通过的记录', {icon: 2, time: 2000});
}else{
ratify(ids, 'ratify','');
}
});
});
<?php $this->endBlock() ?>
</script>
发送请求到controller控制器
public function actionExamine(){
$request = \Yii::$app->request;
if ($request->isAjax) {
$ids = $request->post('ids');
$type = $request->post('type');
$num = count($ids);
$count = User::updateAll(['status'=>0,'created_at'=>time(),'outage_at'=>''],['uid' => $ids]);
if ($count != $num) {
return $this->responseJson(1, '', '预计操作 ' . $num . ' 条记录,实际操作 ' . $count . ' 条记录');
}
return $this->responseJson(0, '', '操作成功!');
}
exit('请求失败');
}
实现