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

6年以前  |  阅读数:406 次  |  编程语言:PHP 

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

例如,


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

一、表格列

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


    <?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. 处理时间

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


    [
     '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. 处理图片


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

3. 数据列有链接


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

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


    [
      '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分页显示制作详细讲解
SSH 登录失败:Host key verification failed
获取IMSI
将二进制数据转为16进制以便显示
文件下载
获取IMEI
贪吃蛇
双位运算符
发送邮件
PHP自定义函数获取搜索引擎来源关键字的方法
Java生成UUID
提取后缀名
年的日历图
在Zeus Web Server中安装PHP语言支持
让你成为最历害的git提交人
Yii2汉字转拼音类的实例代码
再谈PHP中单双引号的区别详解
指定应用ID以获取对应的应用名称
Python 2与Python 3版本和编码的对比
php封装的page分页类完整实例