我有问题,我不能获得必要的值到我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'];
当荫使用$模型 - >米在这个位置,这是正常的情况下工作,我得到一个yii \ base \ ErrorException与'尝试获取非对象的属性'。 – Perino
您确定您的dataProvider是$ dataProviderMembers并且确实包含属性成员..请尝试添加控制器操作代码。 – scaisEdge
是的,dataggridview将被$ dataProviderMembers正确填充。我还可以看到为测试目的而创建的附加列'member'中的正确成员值(复选框列之前的列),我现在还添加了控制器功能的主要部分。 – Perino