亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > PHP > 正文

yii2中結合gridview如何使用modal彈窗實例代碼詳解

2024-05-04 23:47:03
字體:
來源:轉載
供稿:網友

在上篇文章給大家介紹了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導致的,解決該問題只需要在每次異步請求數據之前,移除掉頁面上所有已存在的表單項即可??淳唧w實現:

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

以上所述是小編給大家介紹的yii2中結合gridview如何使用modal彈窗實例代碼詳解的全部敘述,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VeVb武林網網站的支持!


注:相關教程知識閱讀請移步到PHP教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
黑人巨大精品欧美一区二区| 亚洲欧美在线免费| 黄色精品一区二区| 欧美孕妇与黑人孕交| 欧美日韩精品在线观看| 高跟丝袜一区二区三区| 亚洲精品综合久久中文字幕| 亚洲男人的天堂网站| 日韩大胆人体377p| 中文字幕欧美日韩va免费视频| 九九热精品视频在线播放| 亚洲天堂av综合网| 午夜精品三级视频福利| 97久久久久久| 亚洲欧美另类国产| 成人免费观看网址| 亚洲精品成人久久电影| 欧美在线影院在线视频| 国产精品久久久久久久久久久久久久| 九九热这里只有精品6| 夜夜嗨av色一区二区不卡| 久久精品国产99国产精品澳门| 欧美午夜片欧美片在线观看| 欧美一级片一区| 国产亚洲精品久久久优势| 欧美视频第一页| 亚洲欧洲日产国产网站| 欧美综合在线观看| 亚洲美女精品成人在线视频| 精品国产欧美一区二区五十路| 色偷偷av一区二区三区乱| 最近2019中文字幕在线高清| 欧美一级电影免费在线观看| 孩xxxx性bbbb欧美| 成人福利在线观看| 成人av色在线观看| 欧美激情在线有限公司| 日韩电影免费观看中文字幕| 国产精品极品在线| 一区二区三区国产在线观看| 日韩福利伦理影院免费| 久久久97精品| 伊人久久免费视频| 国产精品视频永久免费播放| www.亚洲成人| 欧美性猛交丰臀xxxxx网站| 国产精品mp4| 久久久久日韩精品久久久男男| 久久天天躁狠狠躁夜夜躁2014| 国产精品天天狠天天看| 欧美激情视频在线免费观看 欧美视频免费一| 国产福利成人在线| 欧美疯狂性受xxxxx另类| 色青青草原桃花久久综合| 久久91精品国产91久久久| 国产主播精品在线| 久久免费精品日本久久中文字幕| 精品国产欧美一区二区三区成人| 欧美精品电影免费在线观看| 在线观看欧美日韩国产| 色七七影院综合| 欧美国产日韩视频| 亚洲国产精品推荐| 国产精品国产三级国产aⅴ9色| 中文字幕av一区二区| 在线电影中文日韩| 日本欧美中文字幕| 欧美福利在线观看| 成人精品网站在线观看| 日韩欧美一区二区在线| 国产一区二区免费| 55夜色66夜色国产精品视频| 亚洲视频一区二区| 亚洲精品mp4| 26uuu国产精品视频| 精品国产区一区二区三区在线观看| 日韩精品福利网站| 亚洲第一区中文字幕| 欧美成人三级视频网站| 国内精品一区二区三区四区| 亚洲精品久久久久久久久久久| 亚洲一区二区日本| 91九色国产在线| 精品国产一区二区三区四区在线观看| 国产午夜精品视频免费不卡69堂| 91色琪琪电影亚洲精品久久| 亚洲成人黄色网| 欧美激情在线播放| 久久午夜a级毛片| 成人国产在线激情| 国产日韩欧美夫妻视频在线观看| 66m—66摸成人免费视频| 91热精品视频| 亚洲第一精品久久忘忧草社区| 欧美精品在线观看91| 久久久久久久久国产精品| 久久久久成人精品| 97香蕉超级碰碰久久免费的优势| 日韩欧美一区视频| 疯狂欧美牲乱大交777| 国产精品日韩一区| 一区二区三区在线播放欧美| 亚洲国产成人一区| 18一19gay欧美视频网站| 视频一区视频二区国产精品| 欧美在线一区二区视频| 精品magnet| 日韩国产欧美精品一区二区三区| 精品国产91久久久久久老师| 国产成人精品亚洲精品| 欧美中文在线免费| 亚洲va欧美va国产综合剧情| 国产精品久久国产精品99gif| 国产女精品视频网站免费| 国产精品白丝jk喷水视频一区| 亚洲人成人99网站| 日韩亚洲一区二区| 久久亚洲精品网站| 97色在线观看| 亚洲开心激情网| 亚洲欧美日韩久久久久久| 国内精品久久久久久久久| 中文字幕视频一区二区在线有码| 国产亚洲精品久久久久久777| 欧美一级大片在线观看| 九九久久久久99精品| 久久精品电影网| 欧美一级bbbbb性bbbb喷潮片| 日韩免费观看在线观看| 亚洲成人网久久久| 日韩欧美在线一区| 亚洲欧美日韩成人| 欧日韩在线观看| 成人h视频在线观看播放| 欧美日韩aaaa| 久久久久久国产三级电影| 日韩在线国产精品| 上原亚衣av一区二区三区| 伊人久久久久久久久久久| 一区二区亚洲精品国产| 国产精品视频午夜| 91午夜理伦私人影院| 国产亚洲成av人片在线观看桃| 精品久久久久久久久久久久久久| 日韩av电影免费观看高清| 国产成人精品免高潮费视频| 欧美麻豆久久久久久中文| 亚洲精品一区中文| 久久中国妇女中文字幕| 久久久视频免费观看| 久久精品人人做人人爽| 久久精品99久久久久久久久| 久久久最新网址| 亚洲精品自产拍| 国产日韩精品一区二区| 欧美精品一本久久男人的天堂| 国产精品久久久久久久久久新婚| 欧美激情一级二级| 2019中文字幕在线免费观看| 精品久久久国产精品999| 97婷婷涩涩精品一区| 欧美韩日一区二区| 亚洲电影在线看| 韩国福利视频一区|