關於yii2中結合gridview使用modal彈跳窗的程式碼

不言
發布: 2023-04-01 10:44:01
原創
1635 人瀏覽過

這篇文章主要介紹了yii2中如何結合gridview使用modal彈跳窗的相關資料,需要的朋友可以參考下

在上篇文章給大家介紹了Yii2中如何使用modal彈窗(基本使用),即以建立為例。

實際開發中,我們往往還會遇到列表頁資料修改要使用modal的情況,如果是一般的循環展示,相信大多數人看了modal的基本使用都會操作,但是結合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([
&#39;id&#39; => &#39;update-modal&#39;,
&#39;header&#39; => &#39;<h4 class="modal-title">更新</h4>&#39;,
&#39;footer&#39; => &#39;<a href="#" class="btn btn-primary" data-dismiss="modal">Close</a>&#39;,
]); 
$requestUpdateUrl = Url::toRoute(&#39;update&#39;);
$updateJs = <<<JS
$(&#39;.data-update&#39;).on(&#39;click&#39;, function () {
$.get(&#39;{$requestUpdateUrl}&#39;, { id: $(this).closest(&#39;tr&#39;).data(&#39;key&#39;) },
function (data) {
$(&#39;.modal-body&#39;).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([&#39;index&#39;]);
} else {
return $this->renderAjax(&#39;update&#39;, [
&#39;model&#39; => $model,
]);
}
}
登入後複製

可以看出整個過程中跟我們之前說的modal基本上使用沒什麼差別。但是到此並沒有結束,相信大多數人可能會遇到下面常見的幾個難以解決的問題:

yii2 modal中使用了select2 為什麼搜尋框不可搜尋?

yii2 單一頁面多個modal 為什麼頁面會共用一個,等資料載入完了才好?

yii2 單一頁面多個modal,以單一頁面新增和我們上面的gridview更新均使用modal為例,當使用select2時,為什麼更新的select2會失效不起作用?

在下面我們看如何一個一個的解決掉這些問題:

首先第一個問題,你只需要在modal使用begin的時候指定options選項的tabindex為false即可,參考如下:

Modal::begin([
// ......
&#39;options&#39; => [
&#39;tabindex&#39; => false 
],
]);
登入後複製

第二個和第三個問題,都是在單一頁面中使用多個modal所引起的,為了說明問題,我們在某列表內[建立]按鈕和gridview中[更新]按鈕中均使用modal。按照我們Yii2中如何使用modal彈窗(基本使用)和本篇文章所述,第一個問題很明顯是

$(&#39;.modal-body&#39;).html(data);
登入後複製

所引起的,多個modal,在我們第一次使用modal之後給所有modal的body賦值了,以至於在後面使用其他modal時,在未請求到數據之前均顯示相同內容的bug。解決問題只需要在每次非同步請求之後對各自的modal-body單獨賦值即可,程式碼可參考如下:

$('#create').on('click', function () {
$.get('url', {},
function (data) {
$('#create-modal').find('.modal-body').html(data);
// $(&#39;.modal-body&#39;).html(data);
} 
);
});
$('.data-update').on('click', function () {
$.get('{$requestUpdateUrl}', { id: $(this).closest('tr').data('key') },
function (data) {
$('#update-modal').find('.modal-body').html(data);
// $(&#39;.modal-body&#39;).html(data);
} 
);
});
登入後複製

看最後一個問題,使用過select2的同學要注意了! ! !
如果說像我們本篇主題所介紹的例子這樣,form中帶select2的話,就會導致僅在[創建]時select2正常,[更新]操作時select2字段“隱藏”的效果!

這其實是同一頁面相同select2對應的id導致的,解決該問題只需要在每次非同步請求資料之前,移除頁面上所有已存在的表單項目。看具體實現:

$(&#39;#create&#39;).on(&#39;click&#39;, function () {
// 有效避免multiply modal select2的问题
// 移除异步加载过来的form表单
$(&#39;.document-nav-form&#39;).remove();
$.get(&#39;{$requestUrl}&#39;, {},
function (data) {
$(&#39;#create-modal&#39;).find(&#39;.modal-body&#39;).html(data);
} 
);
});
$(&#39;.data-update&#39;).on(&#39;click&#39;, function () {
// 有效避免multiply modal select2的问题
// 移除异步加载过来的form表单
$(&#39;.document-nav-form&#39;).remove();
$.get(&#39;{$requestUpdateUrl}&#39;, { id: $(this).closest(&#39;tr&#39;).data(&#39;key&#39;) },
function (data) {
$(&#39;#update-modal&#39;).find(&#39;.modal-body&#39;).html(data);
} 
);
});
登入後複製

以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP中文網!

相關推薦:

###關於Yii基於陣列和物件的Model查詢###############Yii和CKEditor實作圖片上傳的功能###############Yii2如何實作同時搜尋多個欄位############################

以上是關於yii2中結合gridview使用modal彈跳窗的程式碼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!