[英]Yii2, how to use another model for display in view file
我很抱歉我的英語。 所以,我有3個表,有很多關系。
並且此代碼在視圖文件中顯示屬性:
<?= DetailView::widget([
'model' => $model,
'attributes' => [
'scientist_id',
'scientist_name',
'scientist_surname',
'scientist_patronymic',
'scientist_birthdate',
'scientist_email:email',
'scientist_phone',
'scientist_photo',
'scientist_status',
'scientist_job:ntext',
'scientist_additional_information:ntext',
'field_id', //display field but no data
],
]) ?>
所以我需要在“field_id”中顯示來自SUMMARY_FIELD表的相應“scientist_id”。 我怎么能這樣做?
科學家模型中與表格的關系:
public function getSummaryFields()
{
return $this->hasMany(SummaryField::className(), ['scientist_id' => 'scientist_id']);
}
public function getFields()
{
return $this->hasMany(Field::className(), ['field_id' => 'field_id'])->viaTable('summary_field', ['scientist_id' => 'scientist_id']);
}
SummaryField模型中的關系:
public function getField()
{
return $this->hasOne(Field::className(), ['field_id' => 'field_id']);
}
/**
* @return \yii\db\ActiveQuery
*/
public function getScientist()
{
return $this->hasOne(Scientist::className(), ['scientist_id' => 'scientist_id']);
}
在Model中創建函數:
function getFieldId($model)
{
$string = '';
foreach ($model->summaryFields as $cat) {
$string .= $cat->field_id . " ";
}
return $string;
}
並在視圖中訪問使用$model->functionName()
:
<?= DetailView::widget([
'model' => $model,
'attributes' => [
[
'attribute'=>'field_id',
'value' => $model->getFieldId($data),
],
],
]); ?>
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.