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)即可。看具體實(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)文章
Zend Framework入門教程之Zend_Mail用法示例
這篇文章主要介紹了Zend Framework中Zend_Mail用法,結(jié)合實(shí)例形式分析了Zend Framework中Zend_Mail組件的功能、使用步驟與相關(guān)操作技巧,需要的朋友可以參考下2016-12-12
php并發(fā)加鎖問(wèn)題分析與設(shè)計(jì)代碼實(shí)例講解
這篇文章主要介紹了php并發(fā)加鎖問(wèn)題分析與設(shè)計(jì)代碼實(shí)例講解,有感興趣的同學(xué)可以跟著研究學(xué)習(xí)下2021-02-02
PHP如何使用JWT做Api接口身份認(rèn)證的實(shí)現(xiàn)
這篇文章主要介紹了PHP如何使用JWT做Api接口身份認(rèn)證的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02
thinkPHP中驗(yàn)證碼的簡(jiǎn)單實(shí)現(xiàn)方法
這篇文章主要介紹了thinkPHP中驗(yàn)證碼的簡(jiǎn)單實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了thinkPHP驗(yàn)證碼的實(shí)現(xiàn)原理、步驟與調(diào)用技巧,需要的朋友可以參考下2016-12-12
Laravel框架實(shí)現(xiàn)model層的增刪改查(CURD)操作示例
這篇文章主要介紹了Laravel框架實(shí)現(xiàn)model層的增刪改查(CURD)操作,結(jié)合實(shí)例形式分析了Laravel框架模型model層進(jìn)行數(shù)據(jù)庫(kù)的增刪改查操作具體實(shí)現(xiàn)技巧,需要的朋友可以參考下2018-05-05
PDO實(shí)現(xiàn)學(xué)生管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了PDO實(shí)現(xiàn)學(xué)生管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-03-03
頁(yè)面利用漸進(jìn)式JPEG來(lái)提升用戶體驗(yàn)度
這篇文章主要介紹了頁(yè)面利用漸進(jìn)式JPEG來(lái)提升用戶體驗(yàn)度的相關(guān)資料,需要的朋友可以參考下2014-12-12
在Laravel中使用GuzzleHttp調(diào)用第三方服務(wù)的API接口代碼
今天小編就為大家分享一篇在Laravel中使用GuzzleHttp調(diào)用第三方服務(wù)的API接口代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-10-10

