Yii2视图B中如何获取模型A的数据

How to get data from model A in view B Yii2

我是 Yii 2 的新手,我目前正在尝试在 GridViewUser 视图中显示来自 Teams 模型的数据。在 Yii1 中,我使用了一个带有 $data 变量的函数。在 Yii2 中,它似乎不是那样工作的。

我在 /user/index.php

中尝试了以下方法
<?php

use yii\helpers\Html;
use yii\grid\GridView;

/* @var $this yii\web\View */
/* @var $dataProvider yii\data\ActiveDataProvider */

$this->title = Yii::t('app', 'Users');
$this->params['breadcrumbs'][] = $this->title;
?>
<div class="user-index">

    <h1><?= Html::encode($this->title) ?></h1>

    <p>
        <?= Html::a(Yii::t('app', 'Create User'), ['create'], ['class' => 'btn btn-success']) ?>
    </p>


    <?= GridView::widget([
        'dataProvider' => $dataProvider,
        'columns' => [
            // ['class' => 'yii\grid\SerialColumn'],
            // 'iduser',
            'username',
            'surname',
            'givenname',
            'email:email',
            'mobile',
            'admin:boolean',
            'language',
            // Below is what I have been trying to do so far...
            ['class' => 'yii\grid\DataColumn',
             'label' => 'Teams',
             'value' => 'getTeams($data-teams)'
            ],
            ['class' => 'yii\grid\ActionColumn'],
        ],
    ]); ?>


</div>

<?php
// And this is the function I use. In Yii1 it worked just fine.
function getTeams($data) {
    $tmp = "";foreach ($data as $team) {
      $tmp .=$team['name'].", ";
    }
    return trim($tmp, ", ");
  }
?>

编辑

User 模型中,这是我设置的如下关系:

public function getTeamIdteams()
    {
        return $this->hasMany(Team::className(), ['idteam' => 'team_idteam'])->viaTable('user_has_team', ['user_iduser' => 'iduser']);
    }

Team 模型中我设置了以下关系:

public function getUserIdusers()
    {
        return $this->hasMany(User::className(), ['iduser' => 'user_iduser'])->viaTable('user_has_team', ['team_idteam' => 'idteam']);
    }

我一直在四处寻找,但似乎找不到解决这个问题的方法。基本上,我只是希望显示用户所属的团队。有一个名为 UserHasTeam 的 table,其中保存了团队和用户的 ID。

我对如何处理整个事情有点迷茫。非常感谢任何帮助。

我假设您已经在用户模型中正确设置了与团队模型的关系。如果您不知道如何设置关系,请参阅指南的 Relations via Junction Table 部分。

您可以在 DataColumn$value 属性 中使用闭包来控制用于列的值。

<?= GridView::widget([
    'dataProvider' => $dataProvider,
    'columns' => [
        // ... other columns ...
        [
            'label' => 'Teams',
            'value' => function($model) {
                $tmp = "";
                foreach ($model->teams as $team) {
                    $tmp .= $team->name .", ";
                }
                return trim($tmp, ", ");
            }
        ],
    ],
]); ?>

您可能还想考虑使用 eager loading 一次加载所有相关内容,而不是 运行 查询网格中的每个用户。