Yii2 Gridview小部件使下拉过滤器选项处于选中状态

时间:2018-10-15 10:24:51

标签: php yii2

嗨,我正在使用yii2 Gridview,并且在我的gridcolumn中有一个filter dropdown选项,同时选择dropdown选项,我的网格结果会正确更改,但是我需要保留选择的dropdown选项filter,请参见下面的代码,

$func = Model::get_rolename();

 GridView::widget([
            'dataProvider' => $dataProvider,
            'filterModel' => $searchmodel,
            'rowOptions' => function($model) {

                return ['data-tt-id' => $model['UserId'], 'data-tt-parent-id' => $model['ManagerId']];
            },
            'options' => ['id' => 'sup_review'],
            'columns' => [

                [
                    'label' => 'First name',
                    'sortLinkOptions' => ['class' => 'desc'],
                    'format' => 'html',
                    'attribute' => 'FirstName',
                    'filterInputOptions' => [
                        'placeholder' => 'Search Name..',
                        'class' => 'form-control',
                    ],
                    'value' => function ($model, $key, $index, $column) {
                        return $model['FirstName'];
                    },
                ],
                [
                    'label' => 'Role test',
                    'sortLinkOptions' => ['class' => 'desc'],
                    'format' => 'ntext',
                    'attribute' => 'ClientId',
                    'filter' => $func,
                    'value' => function ($model, $key, $index, $column) {
                        return $model['RoleName'];
                    },
                ],

                [
                    'label' => 'Actions',
                    'content' => function($model) use ($from, $to) {
                        return Html::a('<span class="btn btn-sm btn-primary">View</span>', Yii::$app->request->baseUrl . '/controller/function/?userid=' . $model['UserId'] . '&from=' . $from . '&to=' . $to, [
                                    'title' => Yii::t('app', 'View'),
                                    'data-pjax' => '0',
                        ]);
                    }
                ],
            ],
        ]);

预先感谢:)

1 个答案:

答案 0 :(得分:1)

是的。这是因为yii2 rbac中的角色存储在项目中,并且有一个单独的表将角色分配给用户。您的代码太紧了,无法猜测后面发生了什么。.但是我猜您正在建立用户索引?无论如何:

  • 您需要Yii::$app->authManager->getRoles();才能获得一系列角色。
  • 您需要在searchModel中加入auth_assignment表

    if($this->role){ $query->join('LEFT JOIN','auth_assignment','auth_assignment.user_id = client_id') ->andFilterWhere(['auth_assignment.item_name' => $this->role]); }

  • 确保您的searchModel包含角色并且该属性是安全的。