yii2中結(jié)合gridview如何使用modal彈窗實例代碼詳解
在上篇文章給大家介紹了Yii2中如何使用modal彈窗(基本使用),即以創(chuàng)建為例。
實際開發(fā)中,我們往往還會遇到列表頁數(shù)據(jù)修改要使用modal的情況,如果是一般的循環(huán)展示,相信大多數(shù)人看了modal的基本使用都會操作,但是結(jié)合gridview估計有些人就開始吃不消了,我們看看如何解決這個問題!
1、gridview的操作增加[更新]按鈕,并指定data-toggle data-target class以及data-id的值
[ 'class' => 'yii\grid\ActionColumn', 'template' => '{update}', 'buttons' => [ 'update' => function ($url, $model, $key) { return Html::a('更新', '#', [ 'data-toggle' => 'modal', 'data-target' => '#update-modal', 'class' => 'data-update', 'data-id' => $key, ]); }, ], ],
2、為更新添加modal
<?php use yii\bootstrap\Modal; // 更新操作 Modal::begin([ 'id' => 'update-modal', 'header' => '<h4 class="modal-title">更新</h4>', 'footer' => '<a href="#" class="btn btn-primary" data-dismiss="modal">Close</a>', ]); $requestUpdateUrl = Url::toRoute('update'); $updateJs = <<<JS $('.data-update').on('click', function () { $.get('{$requestUpdateUrl}', { id: $(this).closest('tr').data('key') }, function (data) { $('.modal-body').html(data); } ); });
JS;
$this->registerJs($updateJs); Modal::end(); ?>
3、修改我們的update方法
public function actionUpdate($id) { $model = $this->findModel($id); if ($model->load(Yii::$app->request->post()) && $model->save()) { return $this->redirect(['index']); } else { return $this->renderAjax('update', [ 'model' => $model, ]); } }
可以看出整個過程中跟我們之前說的modal基本使用沒什么差別。但是到此并沒有結(jié)束,相信大多數(shù)人可能會遇到下面常見的幾個難以解決的問題:
yii2 modal中使用了select2 為什么搜索框不可搜索?
yii2 單個頁面多個modal 為什么頁面會共用一個,等數(shù)據(jù)加載完了才好?
yii2 單個頁面多個modal,以單個頁面添加和我們上面的gridview更新均使用modal為例,當(dāng)使用select2時,為什么更新的select2會失效不起作用?
下面我們看如何一個一個的解決掉這些問題:
首先第一個問題,你只需要在modal使用begin的時候指定options選項的tabindex為false即可,參考如下:
Modal::begin([ // ...... 'options' => [ 'tabindex' => false ], ]);
第二個和第三個問題,都是在單個頁面中使用多個modal所引起的,為了說明問題,我們在某列表內(nèi)[創(chuàng)建]按鈕和gridview中[更新]按鈕中均使用modal。按照我們Yii2中如何使用modal彈窗(基本使用)和本篇文章所述,第一個問題很明顯是
$('.modal-body').html(data);
所引起的,多個modal,在我們第一次使用modal之后給所有modal的body賦值了,以至于在后面使用其他modal時,在未請求到數(shù)據(jù)之前均顯示相同內(nèi)容的bug。解決該問題只需要在每次異步請求之后對各自的modal-body單獨(dú)賦值即可,代碼可參考如下:
$('#create').on('click', function () { $.get('url', {}, function (data) { $('#create-modal').find('.modal-body').html(data); // $('.modal-body').html(data); } ); }); $('.data-update').on('click', function () { $.get('{$requestUpdateUrl}', { id: $(this).closest('tr').data('key') }, function (data) { $('#update-modal').find('.modal-body').html(data); // $('.modal-body').html(data); } ); });
看最后一個問題,使用過select2的同學(xué)要注意了?。。?/p>
如果說像我們本篇主題所介紹的例子這樣,form中帶select2的話,就會導(dǎo)致僅僅在[創(chuàng)建]時select2正常,[更新]操作時select2字段“隱藏”的效果!
這其實是同一頁面相同select2對應(yīng)的id導(dǎo)致的,解決該問題只需要在每次異步請求數(shù)據(jù)之前,移除掉頁面上所有已存在的表單項即可。看具體實現(xiàn):
$('#create').on('click', function () { // 有效避免multiply modal select2的問題 // 移除異步加載過來的form表單 $('.document-nav-form').remove(); $.get('{$requestUrl}', {}, function (data) { $('#create-modal').find('.modal-body').html(data); } ); }); $('.data-update').on('click', function () { // 有效避免multiply modal select2的問題 // 移除異步加載過來的form表單 $('.document-nav-form').remove(); $.get('{$requestUpdateUrl}', { id: $(this).closest('tr').data('key') }, function (data) { $('#update-modal').find('.modal-body').html(data); } ); });
以上所述是小編給大家介紹的yii2中結(jié)合gridview如何使用modal彈窗實例代碼詳解的全部敘述,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- Yii中CArrayDataProvider和CActiveDataProvider區(qū)別實例分析
- 淺析Yii2中GridView常見操作
- yii2.0之GridView自定義按鈕和鏈接用法
- Yii2 GridView實現(xiàn)列表頁直接修改數(shù)據(jù)的方法
- 淺析Yii2 gridview實現(xiàn)批量刪除教程
- 淺析Yii2 GridView實現(xiàn)下拉搜索教程
- 淺析Yii2 GridView 日期格式化并實現(xiàn)日期可搜索教程
- yii2使用GridView實現(xiàn)數(shù)據(jù)全選及批量刪除按鈕示例
- yii2使用gridView實現(xiàn)下拉列表篩選數(shù)據(jù)
- Yii2.0小部件GridView(兩表聯(lián)查/搜索/分頁)功能的實現(xiàn)代碼
- yii2-GridView在開發(fā)中常用的功能及技巧總結(jié)
- YII2框架中ActiveDataProvider與GridView的配合使用操作示例
相關(guān)文章
destoon后臺網(wǎng)站設(shè)置變成空白的解決方法
這篇文章主要介紹了destoon后臺網(wǎng)站設(shè)置變成空白的解決方法,需要的朋友可以參考下2014-06-06Laravel5.0+框架郵件發(fā)送功能實現(xiàn)方法圖文與實例詳解
這篇文章主要介紹了Laravel5.0+框架郵件發(fā)送功能實現(xiàn)方法,結(jié)合圖文與實例形式詳細(xì)分析了Laravel5.0+框架郵件發(fā)送相關(guān)原理、配置、實現(xiàn)方法及操作注意事項,需要的朋友可以參考下2019-04-04ThinkPHP連接數(shù)據(jù)庫及主從數(shù)據(jù)庫的設(shè)置教程
這篇文章主要介紹了ThinkPHP連接數(shù)據(jù)庫及主從數(shù)據(jù)庫的設(shè)置方法,是進(jìn)行大型web項目開發(fā)十分有用的技巧,需要的朋友可以參考下2014-08-08詳解Laravel設(shè)置多態(tài)關(guān)系模型別名的方式
這篇文章主要介紹了Laravel 中簡單設(shè)置多態(tài)關(guān)系模型別名的方式,需要的朋友可以參考下2019-10-10