【问题标题】:how to add relational attributes to gridview yii2?如何将关系属性添加到gridview yii2?
【发布时间】:2018-01-05 05:23:45
【问题描述】:

我有一个新问题 yii2。 如何在视图/视图名称/索引中的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>

如何在此处添加新属性并添加按钮?

【问题讨论】:

    标签: php web yii yii2 frameworks


    【解决方案1】:

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

    关系的函数

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

    并为您需要的字段添加一个吸气剂

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

    最后添加到你的gridview列

    'columns' => [
            ['class' => 'yii\grid\SerialColumn'],
    
            'id',
            'network',
            'technology',
            'sup_id',
            'speaker',
            'your_field',
    

    【讨论】:

    • 有没有办法为此创建 sortby 链接?
    • 如果单击按该属性对它们进行排序,则在每列的顶部单击。但是当它是其他表的属性时,它没有该链接。
    • @areff 。这可能很有用.. 看看场景 2 yiiframework.com/wiki/621/…
    【解决方案2】:

    如何在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'],
            ],
        ]); ?>
    

    有没有办法为此创建 sortby 链接?

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

    【讨论】:

      【解决方案3】:
              [
                  'value'=> 'customer.name',
                  'label' => 'Customer Name',
              ],
      

      试试这个来显示客户的名字!

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

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        相关资源
        最近更新 更多