如何将关系属性添加到gridview yii2?

时间:2017-07-29 04:48:32

标签: php web yii yii2 frameworks

我有一个新问题yii2。 如何在views / viewname / index中显示gridview中其他表的关系值,还为其添加一个按钮以进行确认?

谢谢

<?php

use yii\helpers\Html;
use yii\grid\GridView;

/* @var $this yii\web\View */
/* @var $searchModel app\models\LaptopSearch */
/* @var $dataProvider yii\data\ActiveDataProvider */

$this->title = 'Laptops';
$this->params['breadcrumbs'][] = $this->title;
?>
<div class="laptop-index">

    <h1><?= Html::encode($this->title) ?></h1>
    <?php // echo $this->render('_search', ['model' => $searchModel]); ?>

    <p>
        <?= Html::a('Create Laptop', ['create'], ['class' => 'btn btn-success']) ?>
    </p>
    <?= GridView::widget([
        'dataProvider' => $dataProvider,
        'filterModel' => $searchModel,
        'columns' => [
            ['class' => 'yii\grid\SerialColumn'],

            'id',
            'network',
            'technology',
            'sup_id',
            'speaker',
            // 'optical_drive',
            // 'webcam',
            // 'touchpad',
            // 'card_reader',
            // 'ethernet',
            // 'vga',
            // 'hdmi',
            // 'usb3_ports',
            // 'usb2_ports',
            // 'usb_type_c',
            // 'thunderbolt_ports',
            // 'serial_ports',

            ['class' => 'yii\grid\ActionColumn'],
        ],
    ]); ?>
</div>

如何添加新属性并添加按钮?

3 个答案:

答案 0 :(得分:1)

获取可添加到模型中的相关值

关系的函数

public function getYourRelatedModel()
{
    return $this->hasOne(YourRelatedModel::className(), ['id' => 'your_id_fk']);
}

并为您需要的字段添加一个getter

public function getYour_field() {
    return $this->yourRelatedModel->your_field;
}

并最后添加到gridview列

'columns' => [
        ['class' => 'yii\grid\SerialColumn'],

        'id',
        'network',
        'technology',
        'sup_id',
        'speaker',
        'your_field',

答案 1 :(得分:0)

  

如何在gridview

中显示其他表的关系值

考虑订单和客户模式

按顺序,模型建立客户关系。

public function getCustomer()
{
    return $this->hasOne(Customer::className(), ['id' => 'customer_id']);
}

在订单列表页面中显示客户名称

<?= GridView::widget([
        'dataProvider' => $dataProvider,
        'columns' => [
            ['class' => 'yii\grid\SerialColumn'],

            [
              'label' => 'Customer',
              'attribute' => 'customer_id',
              'value' => function($data) {
                   return $data->customer->name;
               },
            ['class' => 'yii\grid\ActionColumn'],
        ],
    ]); ?>
  

有没有办法为它做出排序链接?

将“属性”添加到网格列,它解决了可排序的问题

答案 2 :(得分:0)

        [
            'value'=> 'customer.name',
            'label' => 'Customer Name',
        ],

尝试此显示客户名称!

如果你想对它进行排序,你需要在searchModel中创建一个customerName伪属性并使用它。