Heim >php教程 >php手册 >利用yii2 gridview实现批量删除案例 - 白狼栈

利用yii2 gridview实现批量删除案例 - 白狼栈

WBOY
WBOYOriginal
2016-05-20 11:40:481464Durchsuche

作者:白狼 出处:http://www.manks.top/article/yii2_gridview_deleteall本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

今天仍然继续探讨GridView的问题,昨天有个小伙伴留言说你用gridview给我去掉表头的链接?我想啊想,这用gridview确实不容易实现,至少我没想出来,会的下方可留言。但是呢,这根gridview有个毛线关联啊,明明是要设置ActiveDataProvider,你要我怎么用gridview实现嘛。

这个问题也是很简单的,我们来看看具体实现

<span style="color: #800080;">$dataProvider</span> = <span style="color: #0000ff;">new</span><span style="color: #000000;"> ActiveDataProvider([ 
</span>'query' => <span style="color: #800080;">$query</span>,<span style="color: #000000;"> 
]); 
</span><span style="color: #800080;">$dataProvider</span>->setSort(<span style="color: #0000ff;">false</span>);

 

分分钟搞定不是事。

好了,我们来谈谈主题:如何利用yii2 gridview实现批量删除?

我先说一下几个步骤啊,免得直接贴代码有的小伙伴删了一句去了一句最后失败了!

1、gridview设置options时增加一个id 这里我们命名grid

'options' =><span style="color: #000000;"> [
</span><span style="color: #008000;">//</span><span style="color: #008000;"> ...其他设置项</span>
'id' => 'grid'<span style="color: #000000;">
]</span>,

 

2、columns增加选项复选框,批量删除必然不可少了复选框操作,这里我们的name值设定为id,方便对数据操作

<span style="color: #000000;">[
    </span>'class' => 'yii\grid\CheckboxColumn',
    'name' => 'id',<span style="color: #000000;">
]</span>,

 

3、页面上我们增加一个批量删除按钮,注意这里我们增加了一个class gridview,方便后面js实现点击效果

= Html::a('批量删除', "javascript:void(0);", ['class' => 'btn btn-success gridview']) ?>

 

4、最后一步,写js实现按钮操作,打开你的console看看,我们很轻松的就拿到了选中的行的id,然后这里就可以异步操作数据了。

<span style="color: #000000;">php
</span><span style="color: #800080;">$this</span>->registerJs('<span style="color: #000000;">
$(".gridview").on("click", function () {
//注意这里的$("#grid"),要跟我们第一步设定的options id一致
    var keys = $("#grid").yiiGridView("getSelectedRows");
    console.log(keys);
});
</span>'<span style="color: #000000;">);
</span>?>

 

下面贴上完整代码

GridView::<span style="color: #000000;">widget([
        </span><span style="color: #008000;">//</span><span style="color: #008000;"> ......</span>
        'options' => ['class' => 'grid-view','style'=>'overflow:auto', 'id' => 'grid'],
        <span style="color: #008000;">//</span><span style="color: #008000;"> ......</span>
        'columns' =><span style="color: #000000;"> [
            </span><span style="color: #008000;">//</span><span style="color: #008000;"> ......</span>
<span style="color: #000000;">            [
                </span>'class' => 'yii\grid\CheckboxColumn',
                'name' => 'id',<span style="color: #000000;">
            ]</span>,
            <span style="color: #008000;">//</span><span style="color: #008000;"> ......</span>
        ],<span style="color: #000000;">
]);
</span><span style="color: #800080;">$this</span>->registerJs('<span style="color: #000000;">
$(".gridview").on("click", function () {
    var keys = $("#grid").yiiGridView("getSelectedRows");
    console.log(keys);
});
</span>');

 

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn