做者:白狼 出处:http://www.manks.top/document/easy_blog_manage_system.html 本文版权归做者,欢迎转载,但未经做者赞成必须保留此段声明,且在文章页面明显位置给出原文链接,不然保留追究法律责任的权利。php
先前咱们讲述了yii2中有关modal的基本使用,即以建立为例。html
实际开发中,咱们每每还会遇到列表页数据修改要使用modal的状况,若是是通常的循环展现,相信大多数人看了modal的基本使用都会操做,可是结合gridview估计有些人就开始吃不消了,咱们看看如何解决这个问题!bootstrap
一、gridview的操做增长[更新]按钮,并指定data-toggle data-target class以及data-id的值yii2
[ '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, ]); }, ], ],
二、为更新添加modalapp
<?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(); ?>
三、修改咱们的update方法yii
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基本使用没什么差异。可是到此并无结束,相信大多数人可能会遇到下面常见的几个难以解决的问题:post
[考虑目前国内网站大部分采集文章十分频繁,更有甚者不注明原文出处,原做者更但愿看客们查看原文,以防有任何问题不能更新全部文章,避免误导!]网站
继续阅读this