• yii2模板


    GridView 小部件在开发中常用的功能及技巧。持续更新中....

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

    例如,

    use yiigridGridView;
    echo yiigridGridView::widget([
        'dataProvider' => $dataProvider,
    ]);

    一、表格列

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

    <?php
    use yiigridGridView;
    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' => 'yiigridSerialColumn'],//序列号从1自增长
            
            // 数据提供者中所含数据所定义的简单的列
            // 使用的是模型的列的数据
            'id',
            'username',
            
            // 更复杂的列数据
            [
                'class' => 'yiigridDataColumn', //由于是默认类型,可以省略 
                'value' => function ($data) {
                    return $data->name; 
                    // 如果是数组数据则为 $data['name'] ,
                    例如,使用 SqlDataProvider 的情形。
                },
            ],
            
            ['label'=>'标题','value' => 'title'],
            
            ['label'=>'文章内容','format' => 'html','value' => 'content'],
                            
            [
                'label'=>'文章类别',  
                /*'attribute' => 'cid',产生一个a标签,点击可排序*/  
                'value' => 'cate.cname' //关联表
            ],
            
            [
               //动作列yiigridActionColumn 
               //用于显示一些动作按钮,如每一行的更新、删除操作。
              'class' => 'yiigridActionColumn',
              '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. 处理时间

    数据列的主要配置项是 yiigridDataColumn::format 属性。它的值默认是使用 yiii18nFormatter 应用组件。

    [
     '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'] 
    ]
  • 相关阅读:
    Delphi 正则表达式之TPerlRegEx 类的属性与方法(3): Start、Stop
    Delphi 正则表达式之TPerlRegEx 类的属性与方法(2): 关于子表达式
    Delphi 正则表达式之TPerlRegEx 类的属性与方法(1): 查找
    Delphi 正则表达式语法(10): 选项
    Delphi 正则表达式语法(9): 临界匹配
    Delphi 正则表达式语法(8): 引用子表达式
    Delphi 正则表达式语法(7): 匹配转义字符
    看阿里P7讲MyBatis:从MyBatis的理解以及配置和实现全帮你搞懂
    公司新来的小姐姐不懂java中的static关键字,这样给她描述不香吗?
    2020阿里,字节跳动,JAVA岗(一线企业校招、社招)面试题合集
  • 原文地址:https://www.cnblogs.com/xiong63/p/6526367.html
Copyright © 2020-2023  润新知