2017-09-07 92 views
0

我使用yii2基本应用程序并使用过滤和搜索的gridview。 我想为每个10条记录分页。我能做什么?为gridview设置分页在yii2基本应用程序中有过滤器

我知道在dataprovider中添加分页,但如何将此添加到我的功能?

请帮帮我。 这对我很重要。 我做很多搜索,但无法找到该

控制器解决方案:

public function actionIndex() 
{ 
    $searchModel = new ContactSearch(); 
    $dataProvider = $searchModel->search(Yii::$app->request->queryParams); 

    return $this->render('index', [ 
     'searchModel'=>$searchModel, 
     'dataProvider' => $dataProvider, 
    ]); 
} 

模型\ contactsearch.php

<?php 
namespace app\models; 

use app\models\Contact; 
use yii\base\Model; 
use yii\data\ActiveDataProvider; 

class ContactSearch extends Contact { 
public function rules() { 
    return [ 

     [['f_name', 'l_name', 'phone_number', 'Mobile_number'], 'safe'], 
    ]; 
} 

public function scenarios() { 
    return Model::scenarios(); 
} 

public function search($params) { 
    $query = Contact::find(); 

    $dataProvider = new ActiveDataProvider([ 
     'query' => $query, 
     'sort' => [ 
    'defaultOrder' => [ 
     'l_name' => SORT_DESC, 
    ], 

], 
    ]); 

    if (!(($this->load($params) && $this->validate()))) { 
     return $dataProvider; 
    } 

    $query->andFilterWhere(['like', 'f_name', $this->f_name]) 
      ->andFilterWhere(['like', 'l_name', $this->l_name]) 
      ->andFilterWhere(['like', 'phone_number', $this->phone_number]) 
      ->andFilterWhere(['like', 'Mobile_number', $this->Mobile_number]); 

      //->andorderBy('id asc'); 

    return $dataProvider; 

} 
} 

?> 

视图

<?= GridView::widget([ 
    'dataProvider' => $dataProvider, 
    'filterModel'=>$searchModel, 
    'columns' => [ 
     ['class' => 'yii\grid\SerialColumn'], 

     'f_name', 
     'l_name', 
     'phone_number', 
     'Mobile_number', 

     ['class' => 'yii\grid\ActionColumn'], 
    ], 
]); ?> 

回答

1

要自定义记录量的GridView

$dataProvider = new ActiveDataProvider([ 
    'query' => $query, 
//show 10 items per page 
'pagination' => [ 
    'pagesize' => 10, 
], 
    'sort' => [ 
'defaultOrder' => [ 
    'l_name' => SORT_DESC, 
], 

其他选项是: stackoverflow link

0

在控制器:

function actionIndex() 
{ 
    $query = Article::find()->where(['status' => 1]); 
    $countQuery = clone $query; 
    $pages = new Pagination(['totalCount' => $countQuery->count()]); 
    $models = $query->offset($pages->offset) 
     ->limit($pages->limit) 
     ->all(); 

    return $this->render('index', [ 
     'models' => $models, 
     'pages' => $pages, 
    ]); 
} 
In view file: 

foreach ($models as $model) { 
    // display $model here 
} 

// display pagination 
echo LinkPager::widget([ 
    'pagination' => $pages, 
]); 
+0

我不明白你的代码。什么是文章,状态,克隆? – tara

+0

文章是我的模态名称,状态是列名称,基于此获取结果。克隆是预定义的函数,用于克隆类,对象或查询等。 – Sucharitha

相关问题