yii2.0 批量操作

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('请求失败');
    }

实现

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值