国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > PHP > 正文

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

2020-03-22 19:16:10
字體:
來源:轉載
供稿:網友
在上篇文章給大家介紹了Yii2中如何使用modal彈窗(基本使用),即以創建為例。實際開發中,我們往往還會遇到列表頁數據修改要使用modal的情況,如果是一般的循環展示,相信大多數人看了modal的基本使用都會操作,但是結合gridview估計有些人就開始吃不消了,我們看看如何解決這個問題!1、gridview的操作增加[更新]按鈕,并指定data-toggle data-target html' target='_blank'>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 更新 /h4 ','footer' = ' a href="#" 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);});以上所述是小編給大家介紹的yii2中結合gridview如何使用modal彈窗實例代碼詳解的全部敘述,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對phpstudy網站的支持!PHP教程

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 丹棱县| 宜丰县| 兴和县| 利辛县| 周口市| 宿州市| 新乡县| 金沙县| 漾濞| 新巴尔虎左旗| 喀什市| 徐汇区| 元阳县| 雷州市| 平和县| 大邑县| 谢通门县| 宣城市| 乐平市| 嵊泗县| 林西县| 建阳市| 林州市| 金塔县| 丹东市| 项城市| 宁河县| 宾阳县| 延边| 锡林浩特市| 肥城市| 民和| 呼玛县| 天气| 石棉县| 上蔡县| 宁南县| 松潘县| 青州市| 庆安县| 临江市|