《PHP應用:yii2中結合gridview如何使用modal彈窗實例代碼詳解》要點:
本文介紹了PHP應用:yii2中結合gridview如何使用modal彈窗實例代碼詳解,希望對您有用。如果有疑問,可以聯系我們。
相關主題:YII框架
PHP學習在上篇文章給大家介紹了Yii2中如何使用modal彈窗(基本使用),即以創建為例.
PHP學習實際開發中,我們往往還會遇到列表頁數據修改要使用modal的情況,如果是一般的循環展示,相信大多數人看了modal的基本使用都會操作,但是結合gridview估計有些人就開始吃不消了,我們看看如何解決這個問題!
PHP學習1、gridview的操作增加[更新]按鈕,并指定data-toggle data-target class以及data-id的值
PHP學習
[
'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,
]);
},
],
],
PHP學習2、為更新添加modal
PHP學習
<?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);
}
);
});
PHP學習JS;
PHP學習
$this->registerJs($updateJs);
Modal::end();
?>
PHP學習3、修改我們的update方法
PHP學習
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,
]);
}
}
PHP學習可以看出整個過程中跟我們之前說的modal基本使用沒什么差別.但是到此并沒有結束,相信大多數人可能會遇到下面常見的幾個難以解決的問題:
PHP學習yii2 modal中使用了select2 為什么搜索框不可搜索?
PHP學習yii2 單個頁面多個modal 為什么頁面會共用一個,等數據加載完了才好?
PHP學習yii2 單個頁面多個modal,以單個頁面添加和我們上面的gridview更新均使用modal為例,當使用select2時,為什么更新的select2會失效不起作用?
PHP學習下面我們看如何一個一個的解決掉這些問題:
PHP學習首先第一個問題,你只需要在modal使用begin的時候指定options選項的tabindex為false即可,參考如下:
PHP學習
Modal::begin([
// ......
'options' => [
'tabindex' => false
],
]);
PHP學習第二個和第三個問題,都是在單個頁面中使用多個modal所引起的,為了說明問題,我們在某列表內[創建]按鈕和gridview中[更新]按鈕中均使用modal.按照我們Yii2中如何使用modal彈窗(基本使用)和本篇文章所述,第一個問題很明顯是
PHP學習
$('.modal-body').html(data);
PHP學習所引起的,多個modal,在我們第一次使用modal之后給所有modal的body賦值了,以至于在后面使用其他modal時,在未請求到數據之前均顯示相同內容的bug.解決該問題只需要在每次異步請求之后對各自的modal-body單獨賦值即可,代碼可參考如下:
PHP學習
$('#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);
}
);
});
PHP學習看最后一個問題,使用過select2的同學要注意了!!!
PHP學習如果說像我們本篇主題所介紹的例子這樣,form中帶select2的話,就會導致僅僅在[創建]時select2正常,[更新]操作時select2字段“隱藏”的效果!
PHP學習這其實是同一頁面相同select2對應的id導致的,解決該問題只需要在每次異步請求數據之前,移除掉頁面上所有已存在的表單項即可.看具體實現:
PHP學習
$('#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);
}
);
});
PHP學習以上所述是小編給大家介紹的yii2中結合gridview如何使用modal彈窗實例代碼詳解的全部敘述,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的.在此也非常感謝大家對維易PHP網站的支持!
轉載請注明本頁網址:
http://www.snjht.com/jiaocheng/6247.html