1

我正在使用 Yii EDataTables 扩展:http ://www.yiiframework.com/extension/edatatables/

我有如下的 EDataTables 小部件

$this->createWidget(
    'ext.EDataTables.EDataTables', array(
        'id'           => 'items',
        'dataProvider' => $dataProvider,
        'ajaxUrl'      => '/ajax-update',
        'columns'      => array(array(
                                'user_id',
                                'email',
                                'name',
                                'created_at:date:Updated',
                                'updated_at:date:Updated',
                                )
        ),
        'options' => array(
            'bStateSave'    => false,
            'bPaginate'     => true,
        ),
    )
);

我想将自定义(值、数组或对象传递给小部件,以便我可以在行值中使用它)

我环顾了很多地方,但我找不到办法。你能建议怎么做吗?

4

1 回答 1

0

假设您有名称的自定义列值,例如:

$nameExp = '$this->grid->options["nameArray"][$data->user_id]';

像这样的数组

$namesInArray = array(
                '1'=>'FirstName LastName 1',
                '2'=>'FirstName LastName 2',
                '3'=>'FirstName LastName 3',
                '4'=>'FirstName LastName 4',
            );

传递不是来自数据提供的额外数据的可能方法是使用选项或 htmloptions 数组发送它(因为小部件的所有其他参数必须在引用的类中具有属性)

因此,您可以在选项数组中传递对象或数组并按如下方式使用它

$nameExp = '$this->grid->options["nameArray"][$data->user_id]';
$namesInArray = array(
    '1'=>'FirstName LastName 1',
    '2'=>'FirstName LastName 2',
    '3'=>'FirstName LastName 3',
    '4'=>'FirstName LastName 4',
);
$this->createWidget(
    'ext.EDataTables.EDataTables', array(
        'id'           => 'items',
        'dataProvider' => $dataProvider,
        'ajaxUrl'      => '/ajax-update',
        'columns'      => array(array(
                                    'user_id',
                                    'email',
                                    'name',
                                    array('class' => 'CDataColumn', 'name' => 'Name from array options', 'sortable' => false, 'value' => $nameExp, 'type' => 'raw'),
                                    'created_at:date:Updated',
                                    'updated_at:date:Updated',
                                )
        ),
        'options' => array(
            'bStateSave'    => false,
            'bPaginate'     => true,
            'nameArray'     => $namesInArray
        ),
    )
);

您将能够使用/访问具有该行值表达式的数组、值或对象,并在那里执行您需要的逻辑!

于 2014-04-04T14:58:32.447 回答