這篇文章將為大家詳細(xì)講解有關(guān)yii2中結(jié)合gridview使用modal彈窗的案例,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
創(chuàng)新互聯(lián)公司從2013年成立,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目成都做網(wǎng)站、網(wǎng)站建設(shè)網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢(mèng)想脫穎而出為使命,1280元望都做網(wǎng)站,已為上家服務(wù),為望都各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話:189820811081、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' => '<h5 class="modal-title">更新</h5>', '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, ]); } }
可以看出整個(gè)過程中跟我們之前說的modal基本使用沒什么差別。但是到此并沒有結(jié)束,相信大多數(shù)人可能會(huì)遇到下面常見的幾個(gè)難以解決的問題:
yii2 modal中使用了select2 為什么搜索框不可搜索?
yii2 單個(gè)頁面多個(gè)modal 為什么頁面會(huì)共用一個(gè),等數(shù)據(jù)加載完了才好?
yii2 單個(gè)頁面多個(gè)modal,以單個(gè)頁面添加和我們上面的gridview更新均使用modal為例,當(dāng)使用select2時(shí),為什么更新的select2會(huì)失效不起作用?
下面我們看如何一個(gè)一個(gè)的解決掉這些問題:
首先第一個(gè)問題,你只需要在modal使用begin的時(shí)候指定options選項(xiàng)的tabindex為false即可,參考如下:
Modal::begin([ // ...... 'options' => [ 'tabindex' => false ], ]);
第二個(gè)和第三個(gè)問題,都是在單個(gè)頁面中使用多個(gè)modal所引起的,為了說明問題,我們?cè)谀沉斜韮?nèi)[創(chuàng)建]按鈕和gridview中[更新]按鈕中均使用modal。按照我們Yii2中如何使用modal彈窗(基本使用)和本篇文章所述,第一個(gè)問題很明顯是
$('.modal-body').html(data);
所引起的,多個(gè)modal,在我們第一次使用modal之后給所有modal的body賦值了,以至于在后面使用其他modal時(shí),在未請(qǐng)求到數(shù)據(jù)之前均顯示相同內(nèi)容的bug。解決該問題只需要在每次異步請(qǐng)求之后對(duì)各自的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); } ); });
看最后一個(gè)問題,使用過select2的同學(xué)要注意了?。。?/p>
如果說像我們本篇主題所介紹的例子這樣,form中帶select2的話,就會(huì)導(dǎo)致僅僅在[創(chuàng)建]時(shí)select2正常,[更新]操作時(shí)select2字段“隱藏”的效果!
這其實(shí)是同一頁面相同select2對(duì)應(yīng)的id導(dǎo)致的,解決該問題只需要在每次異步請(qǐng)求數(shù)據(jù)之前,移除掉頁面上所有已存在的表單項(xiàng)即可??淳唧w實(shí)現(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); } ); });
關(guān)于“yii2中結(jié)合gridview使用modal彈窗的案例”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。
分享標(biāo)題:yii2中結(jié)合gridview使用modal彈窗的案例-創(chuàng)新互聯(lián)
文章路徑:http://muchs.cn/article24/hecje.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)建站、App開發(fā)、網(wǎng)站導(dǎo)航、電子商務(wù)、網(wǎng)站設(shè)計(jì)、移動(dòng)網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容