yii2中結(jié)合gridview如何使用modal彈窗實(shí)例代碼詳解
在上篇文章給大家介紹了Yii2中如何使用modal彈窗(基本使用),即以創(chuàng)建為例。
實(shí)際開(kāi)發(fā)中,我們往往還會(huì)遇到列表頁(yè)數(shù)據(jù)修改要使用modal的情況,如果是一般的循環(huán)展示,相信大多數(shù)人看了modal的基本使用都會(huì)操作,但是結(jié)合gridview估計(jì)有些人就開(kāi)始吃不消了,我們看看如何解決這個(gè)問(wèn)題!
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, ]); } }
可以看出整個(gè)過(guò)程中跟我們之前說(shuō)的modal基本使用沒(méi)什么差別。但是到此并沒(méi)有結(jié)束,相信大多數(shù)人可能會(huì)遇到下面常見(jiàn)的幾個(gè)難以解決的問(wèn)題:
yii2 modal中使用了select2 為什么搜索框不可搜索?
yii2 單個(gè)頁(yè)面多個(gè)modal 為什么頁(yè)面會(huì)共用一個(gè),等數(shù)據(jù)加載完了才好?
yii2 單個(gè)頁(yè)面多個(gè)modal,以單個(gè)頁(yè)面添加和我們上面的gridview更新均使用modal為例,當(dāng)使用select2時(shí),為什么更新的select2會(huì)失效不起作用?
下面我們看如何一個(gè)一個(gè)的解決掉這些問(wèn)題:
首先第一個(gè)問(wèn)題,你只需要在modal使用begin的時(shí)候指定options選項(xiàng)的tabindex為false即可,參考如下:
Modal::begin([ // ...... 'options' => [ 'tabindex' => false ], ]);
第二個(gè)和第三個(gè)問(wèn)題,都是在單個(gè)頁(yè)面中使用多個(gè)modal所引起的,為了說(shuō)明問(wèn)題,我們?cè)谀沉斜韮?nèi)[創(chuàng)建]按鈕和gridview中[更新]按鈕中均使用modal。按照我們Yii2中如何使用modal彈窗(基本使用)和本篇文章所述,第一個(gè)問(wèn)題很明顯是
$('.modal-body').html(data);
所引起的,多個(gè)modal,在我們第一次使用modal之后給所有modal的body賦值了,以至于在后面使用其他modal時(shí),在未請(qǐng)求到數(shù)據(jù)之前均顯示相同內(nèi)容的bug。解決該問(wèn)題只需要在每次異步請(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è)問(wèn)題,使用過(guò)select2的同學(xué)要注意了?。?!
如果說(shuō)像我們本篇主題所介紹的例子這樣,form中帶select2的話,就會(huì)導(dǎo)致僅僅在[創(chuàng)建]時(shí)select2正常,[更新]操作時(shí)select2字段“隱藏”的效果!
這其實(shí)是同一頁(yè)面相同select2對(duì)應(yīng)的id導(dǎo)致的,解決該問(wèn)題只需要在每次異步請(qǐng)求數(shù)據(jù)之前,移除掉頁(yè)面上所有已存在的表單項(xiàng)即可??淳唧w實(shí)現(xiàn):
$('#create').on('click', function () { // 有效避免multiply modal select2的問(wèn)題 // 移除異步加載過(guò)來(lái)的form表單 $('.document-nav-form').remove(); $.get('{$requestUrl}', {}, function (data) { $('#create-modal').find('.modal-body').html(data); } ); }); $('.data-update').on('click', function () { // 有效避免multiply modal select2的問(wèn)題 // 移除異步加載過(guò)來(lái)的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彈窗實(shí)例代碼詳解的全部敘述,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- Yii中CArrayDataProvider和CActiveDataProvider區(qū)別實(shí)例分析
- 淺析Yii2中GridView常見(jiàn)操作
- yii2.0之GridView自定義按鈕和鏈接用法
- Yii2 GridView實(shí)現(xiàn)列表頁(yè)直接修改數(shù)據(jù)的方法
- 淺析Yii2 gridview實(shí)現(xiàn)批量刪除教程
- 淺析Yii2 GridView實(shí)現(xiàn)下拉搜索教程
- 淺析Yii2 GridView 日期格式化并實(shí)現(xiàn)日期可搜索教程
- yii2使用GridView實(shí)現(xiàn)數(shù)據(jù)全選及批量刪除按鈕示例
- yii2使用gridView實(shí)現(xiàn)下拉列表篩選數(shù)據(jù)
- Yii2.0小部件GridView(兩表聯(lián)查/搜索/分頁(yè))功能的實(shí)現(xiàn)代碼
- yii2-GridView在開(kāi)發(fā)中常用的功能及技巧總結(jié)
- YII2框架中ActiveDataProvider與GridView的配合使用操作示例
相關(guān)文章
destoon數(shù)據(jù)庫(kù)表說(shuō)明匯總
這篇文章主要介紹了destoon數(shù)據(jù)庫(kù)表說(shuō)明匯總,可以方便針對(duì)destoon進(jìn)行二次的時(shí)候查詢使用,需要的朋友可以參考下2014-07-07Laravel實(shí)現(xiàn)用戶注冊(cè)和登錄
本文詳細(xì)給我們展示了使用Laravel實(shí)現(xiàn)用戶注冊(cè)和登錄的方法和步鄹,需要的朋友可以參考下2015-01-01destoon后臺(tái)網(wǎng)站設(shè)置變成空白的解決方法
這篇文章主要介紹了destoon后臺(tái)網(wǎng)站設(shè)置變成空白的解決方法,需要的朋友可以參考下2014-06-06PHP PDO預(yù)處理語(yǔ)句及事務(wù)的使用
今天這篇文章,我們來(lái)簡(jiǎn)單的學(xué)習(xí)一下 PDO 中的預(yù)處理語(yǔ)句以及事務(wù)的使用,它們都是在 PDO 對(duì)象下的操作,而且并不復(fù)雜,簡(jiǎn)單的應(yīng)用都能很容易地實(shí)現(xiàn)。只不過(guò)大部分情況下,大家都在使用框架,手寫(xiě)的機(jī)會(huì)非常少。2021-06-06Laravel5.0+框架郵件發(fā)送功能實(shí)現(xiàn)方法圖文與實(shí)例詳解
這篇文章主要介紹了Laravel5.0+框架郵件發(fā)送功能實(shí)現(xiàn)方法,結(jié)合圖文與實(shí)例形式詳細(xì)分析了Laravel5.0+框架郵件發(fā)送相關(guān)原理、配置、實(shí)現(xiàn)方法及操作注意事項(xiàng),需要的朋友可以參考下2019-04-04ThinkPHP連接數(shù)據(jù)庫(kù)及主從數(shù)據(jù)庫(kù)的設(shè)置教程
這篇文章主要介紹了ThinkPHP連接數(shù)據(jù)庫(kù)及主從數(shù)據(jù)庫(kù)的設(shè)置方法,是進(jìn)行大型web項(xiàng)目開(kāi)發(fā)十分有用的技巧,需要的朋友可以參考下2014-08-08詳解Laravel設(shè)置多態(tài)關(guān)系模型別名的方式
這篇文章主要介紹了Laravel 中簡(jiǎn)單設(shè)置多態(tài)關(guān)系模型別名的方式,需要的朋友可以參考下2019-10-10