我想以视图形式显示数组,但我不知道如何显示?有人能帮我吗:我的控制器代码是:
$query = new Query;
$query
->select(['Day_Name'])
->from('days')
->join( 'INNER JOIN','doctorsworkday','doctorsworkday.Day_id =days.dayid');
$command = $query->createCommand();
$dataProvider = $command->queryAll();
$dataProvider= array($dataProvider);
return $this->render('view',
[
'model' => $this->findModel($id),
'days'=>$days,
'doctorsworkday'=>$doctorsworkday,
'dataProvider' => $dataProvider,
])
我的视图代码是:
<?=
DetailView::widget([
'model' => $dataProvider,
'attributes' => [
'Day_Name'
],
])
?>
但它显示:(未设置)
当我使用vat_dump($dataProvider)时,有一个数组。。但我不知道如何展示
输入Var_Dump
首先,您使用DetailView来显示多个结果。DetailView用于显示文档中所述的单个数据模型的详细信息。您可以使用GridView来显示多个结果。GridView接受dataProvider而不是数组,因此您需要将数组转换为dataProvider。
幸运的是,您可以使用ArrayDataProvider类来做到这一点:
$gridViewDataProvider = new 'yii'data'ArrayDataProvider([
'allModels' => $dataProvider,
'sort' => [
'attributes' => ['Day_Name'],
],
'pagination' => ['pageSize' => 10]
]);
这样的东西应该行得通。
然后将$gridViewDataProvider传递给gridview,如下所示:
<?= GridView::widget([
'dataProvider' => $gridViewDataProvider,
'columns' => [
'name'
]
]) ?>
还要注意,在您的控制器中,您将$dataProvider封装在一个数组中,并使用以下行:
$dataProvider= array($dataProvider);
你应该去掉那条线,然后就我所知,一切都应该正常。