我正在使用Yii2 gridview小部件来显示数据。
我使用两个名为消息和 message_trigger 的表。
在消息表中,列为object_model
,Object_id
。
在 message_trigger 中,该列为object_id
,object_name
。
网格获取表消息中的值。因此,网格字段为Object_model
,Object_id
。
现在我的问题是,我需要根据表格消息中的Object_name
来显示表格message_trigger
中的object_id
。
在我的表格中,我使用了像这样的网格
<?= GridView::widget([
'dataProvider' => $dataProvider,
'filterModel' => $searchModel,
'columns' => [
['class' => 'yii\grid\SerialColumn'],
'object_model',
'object_id',
['class' => 'yii\grid\ActionColumn', 'template' => '{view} {update} {delete} '],
],
]); ?>
在模型中我使用了
public function search($params){
$query = AlertTrigger::find()->where(['alert_id'=>$params['id']])->andWhere(['!=','status',2]);
$dataProvider = new ActiveDataProvider([
'query' => $query,
]);
}
答案 0 :(得分:9)
在Message
模型中
public function getMessageTrigger()
{
return $this->hasOne(MessageTrigger::className(), ['object_id' => 'object_id']);
}
在视图中
<?= GridView::widget([
'dataProvider' => $dataProvider,
'filterModel' => $searchModel,
'columns' => [
['class' => 'yii\grid\SerialColumn'],
'object_model',
'object_id',
[
'label' => 'Name',
'value' => 'messageTrigger.object_name',
],
['class' => 'yii\grid\ActionColumn', 'template' => '{view} {update} {delete} '],
],
]); ?>
答案 1 :(得分:3)
ankitraturi answer是最好的答案。如果有人想使用模型中的函数获取值并在gridview中使用它,请按照以下步骤操作。
Message
模型)。public static function get_message_trigger($id){ $model = MessageTrigger::find()->where(["object_id" => $id])->one(); if(!empty($model)){ return $model->object_name; } return null; }
<?= GridView::widget([ 'dataProvider' => $dataProvider, 'filterModel' => $searchModel, 'columns' => [ ['class' => 'yii\grid\SerialColumn'], 'object_model', 'object_id', [ 'label' => 'Name', 'value' => function($data){ return Message::get_message_trigger($data->object_id) }, ], ['class' => 'yii\grid\ActionColumn', 'template' => '{view} {update} {delete} '], ], ]); ?>
希望这会对某人有所帮助。