【发布时间】:2017-09-07 19:15:59
【问题描述】:
我的问题是我无法将必要的值放入我的 gridview 的复选框值字段中。复选框字段可以选中或取消选中。 因此,在数据库中有一个名为 member 的布尔字段,对于具有 0 的数据网格值不检查,而检查 1。
通常gridview 有四列。出于测试目的,我在复选框列前面的额外字段中打印数据库表的列“成员”,以查看表列“成员”的值是否正确。
因为视图有两个不同的 dataProvdider,$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;
使用此方法,复选框字段未正确填写。
通常复选框字段将由段填充
return ['checked' => $model->member};
在这种情况下,没有带有成员值的 $model。 $model 属于 $dataProvider 的数据。
但我从 $dataProviderMembers 获取成员的值。 正如我在“成员”列中看到的那样,它位于数据网格的复选框字段之前,数据库中的值被正确填充到网格中。如何在没有 $model 的情况下填充复选框字段,而不是使用后面的 sql 查询的“成员”列的值($dataProviderMembers 的成员值)?这意味着类似:
return ['checked' => 'member'];
【问题讨论】:
标签: checkbox datagridview yii2 set checked