簡體   English   中英

在CGridView(YII)中不工作過濾器

[英]Not working filter in CGridView (YII)

不在CGridView中使用過濾器元素。 告訴我如何解決這個問題? 例如,您必須選擇一個類別,選擇“寶貝”,但沒有任何反應。 在此輸入圖像描述 SiteController

public function actionIndex()
    {
        $model = new Page;
        $dataProvider=new CActiveDataProvider('Page', array(
            'criteria'=>$criteria,
            'sort' => array(
                'defaultOrder'=>array(
                    'created'=>"DESC"
                )),
            'pagination'=>array(
                'pageSize'=>30,
            ),
        ));

        // renders the view file 'protected/views/site/index.php'
        // using the default layout 'protected/views/layouts/main.php'
        $this->render('index', array('dataProvider'=>$dataProvider,'model'=>$model));
    }

的index.php

$this->widget('zii.widgets.grid.CGridView', array(
    'dataProvider' => $dataProvider,
    'enableSorting'=>true,
    'filter'=>$model,
    'columns' => array(
        'title' => array(
            'name'=>'title',
            'type'=>'raw',
            'value'=>'CHtml::link($data->title,Yii::app()->request->baseUrl."/page/".$data->id)',
            'headerHtmlOptions' => array('style'=>'width:250px;'),
        ),
        'created' => array(
            'name' => 'created',
            'value' => 'date("j.m.Y H:i", $data->created)',
            'headerHtmlOptions' => array('style'=>'width:90px;'),
            'type'=>'raw',
        ),
        'category_id' => array(
            'name' => 'category_id',
            'value' => '$data->category->title',
            'filter' => Category::allCategory(),
            'headerHtmlOptions' => array('style'=>'width:150px; text-align:center;'),
            'type'=>'raw',
            'sortable'=>TRUE
        ),
        'subcategory_id' => array(
            'name' => 'subcategory_id',
            'value' => '$data->subcategory->title',
            'filter' => Subcategory::allCategory(),
            'headerHtmlOptions' => array('style'=>'width:150px; text-align: center;'),
            'type'=>'raw',
        ),
        'condition_id' => array(
            'name' => 'condition_id',
            'value'=> '$data->condition->title',
            'filter' => Condition::allAttributes(),
            'headerHtmlOptions' => array('style'=>'width:90px;'),
            'type'=>'raw',
        ),
    ),
));

在此先感謝您的回答和幫助。

使用將響應您的查詢的數據提供者。

$this->widget('zii.widgets.grid.CGridView', array(
    'dataProvider' => $model->search(), // <== search() function in your model */
    'enableSorting'=>true,
    'filter'=>$model,
    'columns' => array(
     )
);

然后在你的模型中

public function search()
{

    $criteria=new CDbCriteria;

    $criteria->compare('field1',$this->field1,true);

    $criteria->compare('field2',$this->field2);

    return new CActiveDataProvider(get_class($this), array(
        'criteria'=>$criteria,
        'sort'=>array(
            'defaultOrder'=>'field1 ASC',
        ),
        'pagination'=>array(
            'pageSize'=>20
        ),
    ));
}

您沒有從請求中加載POST / GET數據,這就是您沒有獲得任何過濾值的原因。 有更多的方法,我向你展示一個我主要使用的簡單方法;

在你的控制器中這樣做:

    $model = new Page;
    if(isset($_GET['Page']))
        $model->attributes =$_GET['Page'];


        $dataProvider = $model->search();

在您的Page模型中,找到search功能,並在那里調整您的自定義數據提供者(或復制或搜索並稍后使用)

那應該做的。 重要的是 - 您必須從GET請求中的某處設置屬性。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM