PHPIN.NET

 找回密码
 立即注册
查看: 5118|回复: 0

[基础应用] GridView技巧等

[复制链接]

34

主题

2

回帖

731

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
731
发表于 2015-12-14 10:17:48 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

x
  1. <?php
  2. use yii\grid\GridView;
  3. echo GridView::widget([
  4.     'dataProvider' => $dataProvider,
  5.    
  6.     //表格列值搜索功能,注意一定要配合attribute才会显示
  7.     //$searchModel = new ArticleSearch();
  8.     'filterModel' => $searchModel,
  9.    
  10.     //重新定义分页样式
  11.     'layout'=> '{items}<div class="text-right tooltip-demo">{pager}</div>',
  12.     'pager'=>[
  13.         //'options'=>['class'=>'hidden']//关闭分页
  14.         'firstPageLabel'=>"First",
  15.         'prevPageLabel'=>'Prev',
  16.         'nextPageLabel'=>'Next',
  17.         'lastPageLabel'=>'Last',
  18.      ]
  19.         
  20.     'columns' => [
  21.         ['class' => 'yii\grid\SerialColumn'],//序列号从1自增长
  22.         
  23.         // 数据提供者中所含数据所定义的简单的列
  24.         // 使用的是模型的列的数据
  25.         'id',
  26.         'username',
  27.         
  28.         // 更复杂的列数据
  29.         [
  30.             'class' => 'yii\grid\DataColumn', //由于是默认类型,可以省略
  31.             'value' => function ($data) {
  32.                 return $data->name;
  33.                 // 如果是数组数据则为 $data['name'] ,
  34.                 例如,使用 SqlDataProvider 的情形。
  35.             },
  36.         ],
  37.         
  38.         ['label'=>'标题','value' => 'title'],
  39.         
  40.         ['label'=>'文章内容','format' => 'html','value' => 'content'],
  41.                         
  42.         [
  43.             'label'=>'文章类别',  
  44.             /*'attribute' => 'cid',产生一个a标签,点击可排序*/  
  45.             'value' => 'cate.cname' //关联表
  46.         ],
  47.         
  48.         [
  49.            //动作列yii\grid\ActionColumn
  50.            //用于显示一些动作按钮,如每一行的更新、删除操作。
  51.           'class' => 'yii\grid\ActionColumn',
  52.           'header' => '操作',
  53.           'template' => '{delete} {update}',//只需要展示删除和更新
  54.           'headerOptions' => ['width' => '240'],
  55.           'buttons' => [
  56.             'delete' => function($url, $model, $key){
  57.                return Html::a('<i class="fa fa-ban"></i> 删除',
  58.                     ['del', 'id' => $key],
  59.                     [
  60.                      'class' => 'btn btn-default btn-xs',
  61.                      'data' => ['confirm' => '你确定要删除文章吗?',]
  62.                     ]
  63.                );
  64.              },                     
  65.            ],
  66.          ],
  67.         
  68.     ],
  69. ]);
  70. ?>
复制代码



处理时间数据列的主要配置项是 yii\grid\DataColumn::format 属性。
它的值默认是使用 \yii\i18n\Formatter 应用组件。
  1. [
  2. 'label'=>'更新日期',
  3. 'format' => ['date', 'php:Y-m-d'],
  4. 'value' => 'updated_at'
  5. ],

  6. //or
  7. [
  8. //'attribute' => 'created_at',
  9. 'label'=>'更新时间',
  10.   'value'=>function($model){
  11.         return  date('Y-m-d H:i:s',$model->created_at);   
  12.   },
  13. 'headerOptions' => ['width' => '170'],
  14. ],
复制代码


处理图片
  1. [
  2.     'label'=>'封面图',
  3.     'format'=>'raw',
  4.     'value'=>function($m){
  5.         return Html::img($m->cover,
  6.                     ['class' => 'img-circle',
  7.                     'width' => 30]
  8.         );
  9.     }
  10. ],
复制代码


数据列显示枚举值(男/女)
  1. [
  2.    'attribute' => 'sex',  
  3.    'value'=>function ($model,$key,$index,$column){
  4.           return $model->sex==1?'男':'女';   
  5.     },
  6.    
  7.     //在搜索条件(过滤条件)中使用下拉框来搜索
  8.     'filter' => ['1'=>'男','0'=>'女'],
  9.     //or
  10.     'filter' => Html::activeDropDownList($searchModel,
  11.                 'sex',['1'=>'男','0'=>'女'],
  12.                 ['prompt'=>'全部']
  13.      )
  14. ],
  15. [
  16.     'label'=>'产品状态',  
  17.     'attribute' => 'pro_name',  
  18.     'value' => function ($model) {
  19.         $state = [
  20.             '0' => '未发货',
  21.             '1' => '已发货',
  22.             '9' => '退货,已处理',
  23.         ];
  24.      return $state[$model->pro_name];
  25.     },
  26.     'headerOptions' => ['width' => '120']
  27. ]
复制代码

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|小黑屋|PHPIN.NET ( 冀ICP备12000898号-14 )|网站地图

GMT+8, 2024-11-21 20:55

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表