使用Yii2在Gridview中显示相关数据

Win*_*ter 1 php mysql gridview yii2

我已经在相关的模型数据上挣扎了一段时间,似乎无法确定问题,我已经简化为使用一个非常简单的例子.

我有两个模型Dog和Owner,它们有以下关系.

所有者:

public function getDogs()
{
    return $this->hasMany(Dog::className(), ['owner_id' => 'id']);
}
Run Code Online (Sandbox Code Playgroud)

狗:

public function getOwner()
{
    return $this->hasOne(Owner::className(), ['id' => 'owner_id']);
}
Run Code Online (Sandbox Code Playgroud)

作为一个简单的测试,我想让狗从所有者视图中的索引页面中的网格视图中删除,这是我在所有者视图中的index.php

<?= GridView::widget([
    'dataProvider' => $dataProvider,
    'filterModel' => $searchModel,
    'columns' => [
        ['class' => 'yii\grid\SerialColumn'],

        'id',
        'name',
        [       
            'attribute' => 'type',
            'value' => 'dog.type',
        ],

        ['class' => 'yii\grid\ActionColumn'],
    ],
]); ?>
Run Code Online (Sandbox Code Playgroud)

我一定错过了一些基本的东西吗?

soj*_*oju 6

您不能显示这样的多个相关项目,但您可以简单地使用回调,例如:

[
    'label' => 'Dog types',
    'value' => function($model) {
        return join(', ', yii\helpers\ArrayHelper::map($model->dogs, 'id', 'type'));
    },
],
Run Code Online (Sandbox Code Playgroud)