在cgridview中有一个空白字段来过滤每列上面的数据我如何根据多重比较creteria过滤数据,例如我可以在ID列的此字段中输入> 5来过滤数据只是来自id 6及以上。 我想放一些像> 5和< 10我该怎么做
答案 0 :(得分:0)
您创建$filter
YourModel
个实例并实施自定义search()
方法,如图所示here:
控制器:
public function actionIndex() {
$filter = new YourModel('search');
$filter->unsetAttributes();
if (isset($_GET['YourModel']))
$filter->attributes = $_GET['YourModel'];
$this->render('yourview', array(
'filter' => $filter,
));
}
查看:
<?php $this->widget('zii.widgets.grid.CGridView', array(
'dataProvider' => $filter->search(),
'filter' => $filter
...
));
结果,$filter
模型的属性包含用户放在CGridView
的过滤器输入字段中的值,其search()
方法可以解析并以任何方式使用这些值来创建所需的值CDbCriteria然后返回已过滤的CActiveDataProvider。
我没有对它进行测试,但为了过滤模型的某些属性field
,我可以编写如下内容:
public function search()
{
$criteria = new CDbCriteria();
$matches = array();
if (preg_match('/^(<|>)(.+)$/', $this->field, $matches))
{
$criteria->addCondition('field ' . $matches[1] . ' :field');
$criteria->params[':field'] = $matches[2];
}
else
{
$criteria->addCondition('field = :field');
$criteria->params[':field'] = $this->field;
}
// TODO: add conditions for other fields
return new CActiveDataProvider($this, array(
'criteria' => $criteria,
));
}
如果您希望在一个过滤器字段中同时包含<
和>
条件,则由您决定使用哪种格式以及如何解析它以准备搜索条件。
答案 1 :(得分:0)
在我的情况下,我使用此代码:
$matches=array();
if(preg_match('/(.+)(\s)(.+)/',$this->field,$matches)) {
$criteria->addCondition("field ".$matches[1]." and field ".$matches[3]);
} else {
$criteria->compare('field',$this->field);
}
在cgridview中的过滤器输入中,我可以使用“&lt; 100&gt; 50”(在这种情况下,空白字符很重要)