dataprovider数据筛选问题 [ 2.0 版本 ]
控制器和视图的源码在下面,模型源码是GII生成的;
$searchModel = new BodySearch();
$dataProvider = $searchModel->search(Yii::$app->request->queryParams);
GridView::widget([
'dataProvider' => $dataProvider,
'filterModel' => $searchModel,
'columns' => [
['class' => 'yii\grid\CheckboxColumn'],
['class' => 'yii\grid\SerialColumn'],
'created_at',
'col_a',
'col_b',
'col_c',......
'updated_at',
['class' => 'yii\grid\ActionColumn'],
],
]);
按照这样写的方法,gridview会生成一个表格,表格会显示Body里面的所有数据。
而我想要的结果是,只显示Body里面col_d为某个值的所有数据。请问怎么修改
最佳答案
-
那就修改dataProvider数据,而dataProvider应该是通过searchModel生成的,那么去修改searchModel中的过滤条件
$query->andFilterWhere([ $this->col_d => xxx(固定值), ... ]);
共 2 条回复感谢这位同学提醒,我发现在searchmodel里有一个变量负责控制过滤条件,修改之后的代码如下
public function search($params) { $query = Body::find(); // add conditions that should always apply here $dataProvider = new ActiveDataProvider([ 'query' => $query->where(['col_d'=>xxx]), ]); 也就是只要在query后面加一个where条件就行了。
如果搜索条件是一个变量,需要在function search()里面另外传递一个参数,然后将传递进来的参数设置为¥query的条件。
其他 3 个回答
raijin 安徽合肥
注册时间:2016-03-13
最后登录:2022-09-28
在线时长:75小时44分
最后登录:2022-09-28
在线时长:75小时44分
- 粉丝3
- 金钱1880
- 威望0
- 积分2630