ホームページ php教程 php手册 利用yii2 gridview实现批量删除案例 - 白狼栈

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

May 20, 2016 am 11:40 AM

作者:白狼 出处: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>');
ログイン後にコピー

 

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)