9

我正在使用 Yii2 gridview 小部件来显示数据。

我正在使用两个名为messagemessage_trigger的表。

消息表中的列是object_model, Object_id

message_trigger中,列是object_id, object_name

网格从表消息中获取值。所以网格字段是Object_model, Object_id

现在我的问题是我需要根据表格消息Object_name从表格中显示。message_triggerobject_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,
    ]);
}
4

2 回答 2

11

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} '],
    ],
]); ?>
于 2015-09-05T05:53:06.657 回答
4

ankitraturi 答案是最好的答案。如果有人想使用模型中的函数获取价值并在 gridview 中使用它,请按照以下步骤操作。

  1. 在模型中添加返回值的函数(这里我使用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;
}
  1. 在 Gridview 中使用如下所示。
<?= 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} '],
    ],
]); ?>

希望这会对某人有所帮助。

于 2015-11-20T18:37:24.437 回答