關於yii2中結合gridview使用modal彈窗的代碼

來源:互聯網
上載者:User
這篇文章主要介紹了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(['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基本使用沒什麼差別。但是到此並沒有結束,相信大多數人可能會遇到下面常見的幾個難以解決的問題:

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

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

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

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

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

Modal::begin([// ......'options' => ['tabindex' => false ],]);

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

$('.modal-body').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);// $('.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的同學要注意了!!!

如果說像我們本篇主題所介紹的例子這樣,form中帶select2的話,就會導致僅僅在[建立]時select2正常,[更新]操作時select2欄位“隱藏”的效果!

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

$('#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);} );});

以上就是本文的全部內容,希望對大家的學習有所協助,更多相關內容請關注topic.alibabacloud.com!

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.