yii2-girdView的使用(3)——ExpandRowColumn折叠栏的使用

本文详细介绍了在Yii2框架中如何使用GridView组件实现数据表格的折叠栏功能,包括必要的代码块和数据渲染页的实现方式,适用于希望增强数据展示效果的开发者。

以下为个人常用代码块记录:

	<?php
	use yii\helpers\Html;
    use kartik\grid\GridView;//注意引用的类
    ?>
    <?= GridView::widget([
    'dataProvider' => $dataProvider,
    'filterModel' => $searchModel,
    'columns' => [
        ['class' => 'yii\grid\SerialColumn'],
        'vow_name',
         //--------------------------------折叠栏使用的代码块------------------------------------------------
   [
            'class' => 'kartik\grid\ExpandRowColumn',//使用的类
            'value' => function ($model, $key, $index, $column) {
                return GridView::ROW_COLLAPSED;
            },
            'detail' => function ($model, $key, $index, $column) {
                $dataProvider = new \yii\data\ActiveDataProvider([
                    'query' => VowRecord::find()->where(['type'=> 1, 'assistance_id' => $model->user_id]),
                ]);//数据查询构建
                return Yii::$app->controller->renderPartial('/record/help', ['dataProvider' => $dataProvider]);//数据渲染页
            },
            'headerOptions' => ['class' => 'kartik-sheet-style'],
            'expandOneOnly' => true,//是否默认展开数据
        ],
       //---------------------------------折叠栏使用的代码块-------------------------------------------------
     ]
    
]); ?>

详情请看官方文档

要给Yii2-GridView中的自定义字段增加排序功能,可以通过以下步骤实现: 1. 在GridView的columns属性中,为自定义字段添加‘attribute’属性(指定排序用的字段),‘label’属性(指定在表头显示的名称),以及‘value’属性(指定自定义字段的值)。 2. 在GridView的dataProvider属性中,为排序用的字段添加一个Sort属性。 3. 在GridView中的排序链接中,为自定义字段添加一个sort参数,指定排序用的字段。 以下是一个示例代码: ``` use yii\grid\GridView; use yii\data\ActiveDataProvider; use yii\data\Sort; $dataProvider = new ActiveDataProvider([ &#39;query&#39; => $query, &#39;sort&#39; => [ &#39;attributes&#39; => [ &#39;custom_field&#39; => [ &#39;asc&#39; => [&#39;custom_field&#39; => SORT_ASC], &#39;desc&#39; => [&#39;custom_field&#39; => SORT_DESC], &#39;label&#39; => &#39;Custom Field&#39;, ], ], ], ]); echo GridView::widget([ &#39;dataProvider&#39; => $dataProvider, &#39;columns&#39; => [ &#39;id&#39;, &#39;name&#39;, [ &#39;attribute&#39; => &#39;custom_field&#39;, &#39;label&#39; => &#39;Custom Field&#39;, &#39;value&#39; => function ($model) { return $model->customField; } ], ], &#39;sorter&#39; => [ &#39;attributes&#39; => [ &#39;custom_field&#39; => [ &#39;asc&#39; => [&#39;custom_field&#39; => SORT_ASC], &#39;desc&#39; => [&#39;custom_field&#39; => SORT_DESC], ], ], ], ]); ``` 在以上代码中,我们为自定义字段‘custom_field’添加了一个Sort属性,然后在GridView中为该字段添加了‘attribute’、‘label’和‘value’属性。最后,在排序链接中为自定义字段添加了‘sort’参数,指定排序用的字段。这样就可以为Yii2-GridView中的自定义字段增加排序功能了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值