[英]How to get data from model A in view B Yii2
我对 Yii 2 很陌生,我目前正在尝试在 GridView 的User
视图中显示来自Teams
GridView
的数据。 在 Yii1 中,我使用了带有$data
变量的 function。 在 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, ", ");
}
?>
我一直在环顾四周,但似乎无法找到解决方案。 基本上我只是希望显示用户所在的团队。 有一个名为UserHasTeam
的表,其中保存了团队和用户的 ID。
我对如何 go 关于整个事情有点迷茫。 任何帮助是极大的赞赏。
我假设您在用户 model 中正确设置了与团队 model 的关系。 如果您不知道如何设置关系,请参阅指南的通过连接表的关系部分。
您可以在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, ", ");
}
],
],
]); ?>
您可能还想考虑使用预先加载来一次加载所有相关的,而不是为网格中的每个用户运行查询。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.