微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

yii2-GridView在开发中常用的功能及技巧总结

数据网格或者说 GridView 小部件是Yii中最强大的部件之一。它有一个属性名叫 dataProvider ,这个属性能够提供一个数据提供者的示例并且可以显示所提供的数据,即使用 yii\grid\GridView::columns 属性的一组列配置,在一个表格中渲染每一行数据。

例如,

rush:PHP;"> use yii\helpers\Html; use yii\grid\GridView; $dataProvider,'filterModel' => $searchModel,'columns' => [ ['class' => 'yii\grid\SerialColumn'],'id',]);?>

一、表格列

表格的列是通过 GridView 配置项中的 yii\grid\GridView::columns 属性配置的.

rush:PHP;"> $dataProvider,//表格列值搜索功能,注意一定要配合attribute才会显示 //$searchModel = new ArticleSearch(); 'filterModel' => $searchModel,//重新定义分页样式 'layout'=> '{items}
','pager'=>[ //'options'=>['class'=>'hidden']//关闭分页 'firstPageLabel'=>"First",'prevPageLabel'=>'Prev','nextPageLabel'=>'Next','lastPageLabel'=>'Last',]

'columns' => [
['class' => 'yii\grid\SerialColumn'],//序列号从1自增长

// 数据提供者中所含数据所定义的简单的列
// 使用的是模型的列的数据
'id','username',// 更复杂的列数据
[
  'class' => 'yii\grid\DataColumn',//由于是<a href="https://www.jb51.cc/tag/mo/" target="_blank" class="keywords">默</a>认类型,可以省略 
  'value' => function ($data) {
    return $data->name; 
    // 如果是数组数据则为 $data['name'] ,
    例如,使用 <a href="https://www.jb51.cc/tag/sql/" target="_blank" class="keywords">sql</a>DataProvider 的情形。
  },],['label'=>'<a href="https://www.jb51.cc/tag/biaoti/" target="_blank" class="keywords">标题</a>','value' => 'title'],['label'=>'<a href="https://www.jb51.cc/tag/wenzhangneirong/" target="_blank" class="keywords">文章内容</a>','format' => 'html','value' => 'content'],[
  'label'=>'<a href="https://www.jb51.cc/tag/wenzhang/" target="_blank" class="keywords">文章</a>类别',/*'attribute' => 'cid',产生<a href="https://www.jb51.cc/tag/yige/" target="_blank" class="keywords">一个</a>a<a href="https://www.jb51.cc/tag/biaoqian/" target="_blank" class="keywords">标签</a>,点击可排序*/ 
  'value' => 'cate.cname' //关联表
],[
  //动作列yii\grid\ActionColumn 
  //用于<a href="https://www.jb51.cc/tag/xianshi/" target="_blank" class="keywords">显示</a>一些动作按钮,如每一行的更新、<a href="https://www.jb51.cc/tag/shanchu/" target="_blank" class="keywords">删除</a>操作。
 'class' => 'yii\grid\ActionColumn','header' => '操作','template' => '{delete} {update}',//只需要展示<a href="https://www.jb51.cc/tag/shanchu/" target="_blank" class="keywords">删除</a>和更新
 'headerOptions' => ['width' => '240'],'buttons' => [
  'delete' => function($url,$model,$key){
    return Html::a('<i class="fa fa-ban"&gt;</i> <a href="https://www.jb51.cc/tag/shanchu/" target="_blank" class="keywords">删除</a>',['del','id' => $key],[
       'class' => 'btn btn-default btn-xs','data' => ['confirm' => '你确定要<a href="https://www.jb51.cc/tag/shanchu/" target="_blank" class="keywords">删除</a><a href="https://www.jb51.cc/tag/wenzhang/" target="_blank" class="keywords">文章</a>吗?',]
      ]
    );
   },]);

?>

1. 处理时间

数据列的主要配置项是 yii\grid\DataColumn::format 属性。它的值认是使用 \yii\i18n\Formatter 应用组件。

'更新日期','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. 处理图片

'封面图','format'=>'raw','value'=>function($m){ return Html::img($m->cover,['class' => 'img-circle','width' => 30] ); } ],

3. 数据列有链接

'title','value' => function ($model,$key,$index,$column) { return Html::a($model->title,['article/view','id' => $key]); },'format' => 'raw',

4. 数据列显示枚举值(男/女)

'sex','value'=>function ($model,$column){ return $model->sex==1?'男':'女'; },

//在搜索条件(过滤条件)中使用下拉框来搜索
'filter' => ['1'=>'男','0'=>'女'],//or
'filter' => Html::activeDropDownList($searchModel,'sex',['1'=>'男',['prompt'=>'全部']
)
],[
'label'=>'产品状态','attribute' => 'pro_name','value' => function ($model) {
$state = [
'0' => '未发货','1' => '已发货','9' => '退货,已处理',];
return $state[$model->pro_name];
},'headerOptions' => ['width' => '120']
]

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐