Yii2 GridView当前行号第一最后一行

时间:2018-08-10 14:06:49

标签: php gridview yii2

我需要Yii2 GridView的帮助。我正在渲染一张桌子,但我想在第一行和最后一行上放置特殊图标。有没有办法知道在哪一行?

    <?= GridView::widget([
    'dataProvider' => $dataProvider,
    "tableOptions" => ['class' => 'table table-striped table-bordered brand-list',"style"=> ""],
    /*'filterModel' => $searchModel,*/
    'columns' => [                  
        ['class' => 'yii\grid\SerialColumn'],

        [
            'class' => 'yii\grid\ActionColumn',
            'template' => '{sort-up}   {sort-down}',

            'buttons' => [
                        'sort-up' => function ($url, $brand, $key)  {
                            $url = \Yii::$app->urlManager->createUrl(["brand/sort", 'id' => $brand->id , 'dir' => 'up']);
                            return Html::a( ""  , '#', ['data-url' => $url, 'title' => "test",
                                                     'data-title' => "sort up",
                                                    'class' => 'glyphicon glyphicon-chevron-up']);

                        },
                        'sort-down' => function ($url, $brand, $key) {                                
                            $url = \Yii::$app->urlManager->createUrl(["brand/sort", 'id' => $brand->id , 'dir' => 'down']);
                            return Html::a('', '#', ['data-url' => $url, 'title' => "test",
                                                     'data-title' => "sort up",
                                                    'class' => 'glyphicon glyphicon-chevron-down']);
                        },
            ],
        ],            
        [
            'attribute' => 'name',                
            'label' => Yii::t('admin:brand', 'brand_name'),                
        ],                        
    ],      
]); ?>

类似:

'buttons' => [
                    'sort-up' => function ($url, $brand, $key)  {
                        if($currentRow == 1){
                        return "firstRow";
                        }


                    },
                    'sort-down' => function ($url, $brand, $key) {                                
                        if($currentRow == ROWS_COUNT){
                            return "lastRow";
                        }
                    },
        ],

感谢您的帮助。 问候 韦尔

1 个答案:

答案 0 :(得分:0)

使用$dataprovider->models构建当前页面中显示的所有模型的地图,
然后,您可以使用array_search()获取当前索引,或者仅使用reset()end()获取第一项和最后一项

// map will contain all model ids in the the same order they are displayed in
$map = ArrayHelper::getColumn($dataprovider->models);

echo GridView::widget([
    'dataProvider' => $dataProvider,
    // ...
    'columns' => [
        // ...
        [
            'class' => 'yii\grid\ActionColumn',
            'buttons' => [
                'sort-up' => function ($url, $brand, $key) use ($map) {
                    if ($key == reset($map)){
                        return "firstRow";
                    }
                },
                'sort-down' => function ($url, $brand, $key) use ($map) {                                
                    if($key == end($map)){
                        return "lastRow";
                    }
                },
            ]
        ]
    ]
])