Yii2视图B中如何获取模型A的数据
How to get data from model A in view B Yii2
我是 Yii 2 的新手,我目前正在尝试在 GridView
的 User
视图中显示来自 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 一次加载所有相关内容,而不是 运行 查询网格中的每个用户。
我是 Yii 2 的新手,我目前正在尝试在 GridView
的 User
视图中显示来自 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 一次加载所有相关内容,而不是 运行 查询网格中的每个用户。