2017-09-07 42 views
1

我有问题,我不能获得必要的值到我gridview的复选框值字段。复选框字段可以选中或取消选中。 因此,在数据库中有一个名为member的布尔字段,对于datagrid值为0的值没有被检查,并且检查了1。

通常gridview有四列。出于测试目的,我在复选框列前面的额外字段中打印数据库表的列“成员”,以查看表列“成员”的值是否正确。

因为视图有两个不同的dataProvdiders,$ dataProvider和$ dataProviderMembers,所以我不能使用$ model对象。 $ model对象属于$ dataProvider的内容。 dataviewgrid将由第二个数据提供者$ dataProviderMembers填充。

<?= GridView::widget([ 
     'dataProvider' => $dataProviderMembers, 
     'columns' => [ 
      ['class' => 'yii\grid\SerialColumn'], 
      'id', 
      'firstname', 
      'lastname', 
      'member', 
      ['class' => 'yii\grid\CheckboxColumn', 'checkboxOptions' => function($model, $key, $index, $column){ 
       return ['checked' => 'member']; 
      }, 'header' => 'Mitglied' 
      ], 
      ] 
    ]); ?> 

控制器梅索德:

$searchModel = new PeriodeClassSubjectMembersSearch(); 
     $dataProvider = $searchModel->search(Yii::$app->request->queryParams); 

$modelPeriodeClassSubjectMembers = new PeriodeClassSubjectMembers(); 
     $dataProviderMembers = $modelPeriodeClassSubjectMembers->getPeriodeClassMembers($class_id, $periode_id, false); 
     $dataProviderMembers->key = 'id'; //set this to make the id column as value columns in the gridview for javascript getselectedrows instead of the gridrow number 
     return $this->render('viewmysubject', [ 
      'model' => $this->findModel($id), 
      'searchModel' => $searchModel, 
      'dataProvider' => $dataProvider, 
      'dataProviderMembers' => $dataProviderMembers 
     ]); 

型号为梅索德$ dataProviderMembers:

$query = new Query(); 
     $query->select(..........); 

$dataProvider = new ActiveDataProvider([ 
    'query' => $query, 
]); 

return $dataProvider; 

使用这种方法,该复选框场不填充correkt。

普通的复选框场将由段

return ['checked' => $model->member}; 

填写在这种情况下,有一个带有成员值没有$模型。 $模型属于$ dataProvider的数据。

但我从$ dataProviderMembers获得成员的值。 正如我在datagrid的复选框字段之前的'member'列中所看到的那样,来自数据库的值正好填充到网格中。我怎样才能填充复选框字段没有$模型,而是在后面的sql查询的'成员'列的值($ dataProviderMembers的成员值)?这意味着类似:

return ['checked' => 'member']; 

回答

1

在你的GridView的数据提供程序等于$ dataProviderMembers 然后在匿名函数的$模型参数有关checkboxOptions是有关应包含成员值 所以你可以得到价值模型使用$模型 - >构件

 [ 'class' => 'yii\grid\CheckboxColumn', 
      'checkboxOptions' => function($model, $key, $index, $column){ 
      return ['value' => $model->member]; 
      }, 
     ], 

,或者如果dataProvider是一个数组

 [ 'class' => 'yii\grid\CheckboxColumn', 
      'checkboxOptions' => function($model, $key, $index, $column){ 
      return ['value' => $model['member']]; 
      }, 
     ], 
+0

当荫使用$模型 - >米在这个位置,这是正常的情况下工作,我得到一个yii \ base \ ErrorException与'尝试获取非对象的属性'。 – Perino

+0

您确定您的dataProvider是$ dataProviderMembers并且确实包含属性成员..请尝试添加控制器操作代码。 – scaisEdge

+0

是的,dataggridview将被$ dataProviderMembers正确填充。我还可以看到为测试目的而创建的附加列'member'中的正确成员值(复选框列之前的列),我现在还添加了控制器功能的主要部分。 – Perino