如何将数组作为Yii2 gridview列的参数传递

时间:2014-08-12 08:09:00

标签: php yii yii2

我正在尝试将$arr_judete_v2作为参数传递给gridview中的回调函数,但它不起作用;

$model['county_id']会返回一个数字

$arr_judete_v2[1]['nume']返回一个名称

我的问题:

[
                    'attribute' => 'county_id',
                    'label' => Yii::t('diverse', 'Judet'),
                    'content' => function($model, $arr_judete_v2) {
                        return $arr_judete_v2[$model['county_id']]['nume'];
                    },
                ],

整个gridview

<?php
    echo GridView::widget([
        'layout' => "{items}",
        'dataProvider' => $dataProvider,
        'columns' => [
            'id',
            [
                'attribute' => 'nume',
                'label' => Yii::t('companie', 'nume'),
            ],
            'cui',
            'email',
            [
                'attribute' => 'county_id',
                'label' => Yii::t('diverse', 'Judet'),
                'content' => function($model, $arr_judete_v2) {
                    return $arr_judete_v2[$model['county_id']]['nume'];
                },
            ],
            [
                'class' => 'yii\grid\ActionColumn',
                'template' => '{update} {delete}',
                'buttons' => [
                    'update' => function ($url, $model) {
                        return Html::a('<span class="glyphicon glyphicon-pencil"></span>', ['update', 'id' => $model['id']], [
                                    'title' => Yii::t('yii', 'Update'),
                                    'data-pjax' => '0',
                        ]);
                    }
                ]
            ],
        ],
    ]);

2 个答案:

答案 0 :(得分:11)

来自the source code for \Yii\grid\Column

  

@var callable这是一个可调用的,用于生成每个单元格的内容。     该函数的签名应如下:function ($model, $key, $index, $column)

作为Mihai has correctly pointed out,您可以使用use()将变量包含到函数的范围中,如下所示:

"content" => function($model, $key, $index, $column) use ($arr_judete_v2) {
    return $arr_judete_v2[$model['county_id']]['nume'];
}

请注意,变量会复制到函数中,因此任何更改都不会影响函数外部的变量。对in this answer进行了更好的解释。

答案 1 :(得分:3)

使用use(),查看如何为列的值定义函数。

        $invoice_status_data = array('' => 'Select a status') + ArrayHelper::map(InvoiceStatus::find()->asArray()->all(), 'id', 'name');
    ........................
            'columns' => [
    ........................
                        [
                            'attribute'=>'Contact.name',
                            'format'=>'raw',
                            'value'=>function ($model, $key, $index, $widget) use ($invoice_status_data) {
.............................
                                    $content .= 
                                        Html::dropDownList('dropdown'. $model->id, '', $invoice_status_data, [
                                            'class' => 'form-control', 
                                            'onchange' => 'javascript: myInvoice.change($(this));', 
                                            'data-href' => Url::toRoute(['invoice/change-status', "Invoice_id"=>$model->id])]);


                                return $content;
                            },
                        ],