《PHP编程:浅析Yii2中GridView常见操作》要点:
本文介绍了PHP编程:浅析Yii2中GridView常见操作,希望对您有用。如果有疑问,可以联系我们。
相关主题:YII框架
本文是小编给大家收集整理些有关网络上GridView出现的大部分问题,本文做一个总结特此分享到维易PHP平台供大家参考.PHP实战
如果下面有没说到的GridView常见问题,下方留言,我会进行补充.PHP实战
下拉搜索PHP实战
日期格式化并实现日期可搜索PHP实战
根据参数进行是否显示PHP实战
链接可点击跳转PHP实战
显示图片PHP实战
html渲染PHP实战
自定义按钮PHP实战
设定宽度等样式 PHP实战
自定义字段PHP实战
自定义行样式PHP实战
增加按钮调用js操作PHP实战
yii2 GridView 下拉搜索实现案例教程PHP实战
yii2 GridView 日期格式化并实现日期可搜索 案例PHP实战
是否显示某列案例PHP实战
我们举一个简单的案例PHP实战
条件:有一个get形参数typePHP实战
需求:仅且type的值等于1的时候,列name才显示,否则该列不显示PHP实战
代码实现如下:PHP实战
[ 'attribute' => 'name', 'value' => $model->name, 'visible' => intval(Yii::$app->request->get('type')) == 1, ],
实现方式也是很简单滴.PHP实战
链接可点击跳转案例PHP实战
这个跟接下来我们要说的html渲染的效果十分类似,这里要说的是列的属性值 format,具体都有哪些格式可查看文件 yii\i18n\Formatter.php,各种format都可以办理PHP实战
[ 'attribute' => 'order_id', 'value' => function ($model) { return Html::a($model->order_id, "/order?id={$model->order_id}", ['target' => '_blank']); }, 'format' => 'raw', ],
显示图片案例PHP实战
同上,这里只需要指定format格式为image即可,format第二个参数可设定图片大小,可参考下面的代码PHP实战
[ 'label' => '头像', 'format' => [ 'image', [ 'width'=>'84', 'height'=>'84' ] ], 'value' => function ($model) { return $model->image; } ],
html渲染案例PHP实战
什么意思喃,举个例子,我们有一个字段,标记为title,但是这个title不一样,ta含有html标签,我们不想在页面上展示<p>title123<p>这种形式,我们想要title123以p标签的形式展示,代码可参考如下,只需要指定format为raw形式即可PHP实战
[ 'attribute' => 'title', 'value' => function ($model) { return Html::encode($model->title); }, 'format' => 'raw', ],
自定义按钮案例PHP实战
往往列表页我们不想要删除按钮,想在增加一个比如获取xxx按钮,怎么搞呢?这里需要设置ActionColumn类,修改配置项template并在buttons项增加template里增加的get-xxx即可PHP实战
[ 'class' => 'yii\grid\ActionColumn', 'template' => '{get-xxx} {view} {update}', 'header' => '操作', 'buttons' => [ 'get-xxx' => function ($url, $model, $key) { return Html::a('获取xxx', $url, ['title' => '获取xxx'] ); }, ], ],
设定宽度案例PHP实战
举个简单的例子,我们的title列,太长了,能不能给我先定下这一列的宽度?PHP实战
答案:能.PHP实战
请看示例:PHP实战
[ 'attribute' => 'title', 'value' => 'title', 'headerOptions' => ['width' => '100'], ],
只需要指定配置项headerOptions即可.PHP实战
自定义字段案例PHP实战
啥时自定义?这里我们是指在表格里增加一列且数据库中不存在对应的列.假如我们新增一列 订单消费金额money且该表不存在该字段PHP实战
[ 'attribute' => '消费金额', 'value' => function ($model) { // 这里可以根据该表的其他字段进行关联获取 } ],
自定义行样式PHP实战
有小伙伴说了,gii生成的这个gridview表格呀,行跟行的颜色不明显,看着难受,我滴乖乖,具体怎么难受咱们就不追究了.我们来看看怎么定义行样式PHP实战
<?= GridView::widget([ // ...... 'dataProvider' => $dataProvider, 'rowOptions' => function($model, $key, $index, $grid) { return ['class' => $index % 2 ==0 ? 'label-red' : 'label-green']; }, // ...... ]); ?>
前面的操作我们都是依据列column的,这里因为是对行的控制,所以我们配置rowOptions要稍微注意一下.此外,自定义的label-red和label-green需要有对应的样式实现,这里我们看一下页面的实际效果PHP实战
增加按钮调用js操作案例PHP实战
那边产品经理走过来了,小王呀,你这个修改状态的功能很频繁,每次都要先点进详情页才能修改,能不能我在列表页面上鼠标那么一点就成功修改了呢?PHP实战
其实就是一个异步哀求操作了当前行的状态嘛,我们来看看gridview里面是怎么实现的.PHP实战
[ 'class' => 'yii\grid\ActionColumn', 'header' => '操作', 'template' => '{view} {update} {update-status}', 'buttons' => [ 'update-status' => function ($url, $model, $key) { return Html::a('更新状态', ';', ['onclick'=>'update_status(this, '.$model->id.');']); }, ], ],
我们需要在页面写js实现方法 update_status, 关于如安在页面底部加载js请点击参考PHP实战
补充:GridView 小部件在开发中常用的功能及技巧.PHP实战
数据网格或者说 GridView 小部件是Yii中最强大的部件之一.PHP实战
它有一个属性名叫 dataProvider ,这个属性能够提供一个数据提供者的示例并且可以显示所提供的数据,即使用 yii\grid\GridView::columns 属性的一组列配置,在一个表格中渲染每一行数据.PHP实战
例如,PHP实战
use yii\grid\GridView; echo yii\grid\GridView::widget([ 'dataProvider' => $dataProvider, ]);
一、表格列PHP实战
表格的列是通过 GridView 配置项中的 yii\grid\GridView::columns 属性配置的.PHP实战
<?php use yii\grid\GridView; echo GridView::widget([ 'dataProvider' => $dataProvider, //表格列值搜索功能,注意一定要配合attribute才会显示 //$searchModel = new ArticleSearch(); 'filterModel' => $searchModel, //重新定义分页样式 'layout'=> '{items}<div class="text-right tooltip-demo">{pager}</div>', 'pager'=>[ //'options'=>['class'=>'hidden']//关闭分页 'firstPageLabel'=>"First", 'prevPageLabel'=>'Prev', 'nextPageLabel'=>'Next', 'lastPageLabel'=>'Last', ] 'columns' => [ ['class' => 'yii\grid\SerialColumn'],//序列号从1自增长 // 数据提供者中所含数据所定义的简单的列 // 使用的是模型的列的数据 'id', 'username', // 更复杂的列数据 [ 'class' => 'yii\grid\DataColumn', //由于是默认类型,可以省略 'value' => function ($data) { return $data->name; // 如果是数组数据则为 $data['name'] , 例如,使用 SqlDataProvider 的情形. }, ], ['label'=>'标题','value' => 'title'], ['label'=>'文章内容','format' => 'html','value' => 'content'], [ 'label'=>'文章类别', /*'attribute' => 'cid',产生一个a标签,点击可排序*/ 'value' => 'cate.cname' //关联表 ], [ //动作列yii\grid\ActionColumn //用于显示一些动作按钮,如每一行的更新、删除操作. 'class' => 'yii\grid\ActionColumn', 'header' => '操作', 'template' => '{delete} {update}',//只需要展示删除和更新 'headerOptions' => ['width' => '240'], 'buttons' => [ 'delete' => function($url, $model, $key){ return Html::a('<i class="fa fa-ban"></i> 删除', ['del', 'id' => $key], [ 'class' => 'btn btn-default btn-xs', 'data' => ['confirm' => '你确定要删除文章吗?',] ] ); }, ], ], ], ]); ?>
1. 处理时间PHP实战
数据列的主要配置项是 yii\grid\DataColumn::format 属性.
它的值默认是使用 \yii\i18n\Formatter 应用组件.PHP实战
[ 'label'=>'更新日期', 'format' => ['date', 'php:Y-m-d'], 'value' => 'updated_at' ], //or [ //'attribute' => 'created_at', 'label'=>'更新时间', 'value'=>function($model){ return date('Y-m-d H:i:s',$model->created_at); }, 'headerOptions' => ['width' => '170'], ],
2. 处理图片PHP实战
[ 'label'=>'封面图', 'format'=>'raw', 'value'=>function($m){ return Html::img($m->cover, ['class' => 'img-circle', 'width' => 30] ); } ],
3. 数据列有链接PHP实战
[ 'attribute' => 'title', 'value' => function ($model, $key, $index, $column) { return Html::a($model->title, ['article/view', 'id' => $key]); }, 'format' => 'raw', ],
4. 数据列显示枚举值(男/女)PHP实战
[ 'attribute' => 'sex', 'value'=>function ($model,$key,$index,$column){ return $model->sex==1?'男':'女'; }, //在搜索条件(过滤条件)中使用下拉框来搜索 'filter' => ['1'=>'男','0'=>'女'], //or 'filter' => Html::activeDropDownList($searchModel, 'sex',['1'=>'男','0'=>'女'], ['prompt'=>'全部'] ) ], [ 'label'=>'产品状态', 'attribute' => 'pro_name', 'value' => function ($model) { $state = [ '0' => '未发货', '1' => '已发货', '9' => '退货,已处理', ]; return $state[$model->pro_name]; }, 'headerOptions' => ['width' => '120'] ]
维易PHP推荐阅读:PHP实战
浅析Yii2中GridView常见操作PHP实战
yii2 页面底部加载css和js的技巧PHP实战
浅析Yii2 GridView 日期格式化并实现日期可搜索教程PHP实战
以上内容是针对Yii2中GridView常见操作的全部介绍,希望对大家有所赞助!PHP实战
《PHP编程:浅析Yii2中GridView常见操作》是否对您有启发,欢迎查看更多与《PHP编程:浅析Yii2中GridView常见操作》相关教程,学精学透。维易PHP学院为您提供精彩教程。
转载请注明本页网址:
http://www.vephp.com/jiaocheng/6861.html