在CGridView中过滤自定义列(具有模型中自定义方法的值)

时间:2013-06-05 05:57:53

标签: php yii

以下是我在view.php文件中的代码

$this->widget('zii.widgets.grid.CGridView', array(
        'id' => 'myGrid',
        'dataProvider' => $model->search(),
        'filter' => $model,
        'enableSorting' => true,
        'columns' => array(
            array(
                'name' => 'id',
                'header' => 'ID',
                'value' => $data->id,                
            ),
            array(
                'header' => 'Value', 
                'value' => '$data->getValue($data->id)', //getValue($id) is a custom method in the model.php file which returns a value after some calculations                    
                'filter' => $model->listOfFilterValues(), //listOfFilterValues() is a custom method in the model.php file which returns a CHtml::listData
            ),            
        ),
       )
    );

正如您所看到的,我在model.php文件中使用自定义方法来获取Value列(因为我无法从查询中获取它)。 将出现gridView,并显示下拉列表。到目前为止工作正常。

问题是使用下拉列表(在“值”列中)进行过滤不起作用。 (因为它不是查询输出中的列)     而且Value列上的排序(当我点击列标题时)也不起作用。

有没有办法完成这项工作?非常感谢您的帮助。谢谢。

1 个答案:

答案 0 :(得分:1)

试试这个:

在模特:

class Plans extends BasePlans
{
 ...
public $planTypeSearch;
 ...

public function search() {    
...     
$criteria->compare('plan.plan_type', $this->planTypeSearch, true);
...
),
return new CActiveDataProvider($this, array(
    'criteria' => $criteria,
    'sort'=>array(
        'attributes'=>array(
            'planTypeSearch'=>array(
                 'asc'=>'plan.plan_type',
                 'desc'=>'plan.plan_type DESC',
             ),
         ),
     ),
 );

在您看来:

array(
    'name'=>'planTypeSearch',
    'header'=> 'Plan Type',
    'value'=>'(isset($data->plan)) ? $data->plan->plan_type: null',
    'filter'=>isset($plans) ? CHtml::listData($plans, 'plan_type','plan_type') : NULL,
),