我有一个用Gii代码生成器生成的index.php
文件。它具有一个GridView,其中包含我数据库表的数据。它具有536000行,因此它的移动速度非常慢。有时甚至超过30秒,因此根本无法加载页面。
我想启动索引文件(http://localhost:8080/persons/index.php),但使用一个空的GridView(或不使用GridView),并且当用户使用_search.php
文件的过滤器时可以将其填充。
我的index.php文件:
<? Pjax::begin() ?>
<? echo $this->render('_search', ['model' => $searchModel]) ?>
<?= GridView::widget([
'dataProvider' => $dataProvider,
'filterModel' => $searchModel,
'columns' => [
'id',
'name',
'details',
],
]) ?>
<? Pjax::end() ?>
我的_search.php文件:
<?php $form = ActiveForm::begin([
'action' => ['index'],
'method' => 'get',
'options' => [
'data-pjax' => 1
],
]) ?>
<?= $form->field($model, 'name') ?>
<?= $form->field($model, 'datails') ?>
<div class="form-group">
<?= Html::submitButton('Search', ['class' => 'btn btn-primary']) ?>
<?= Html::resetButton('Reset', ['class' => 'btn btn-default']) ?>
</div>
<? ActiveForm::end() ?>
我的peopleController.php文件:
public function actionIndex()
{
$searchModel = new PersonsSearch();
$dataProvider = $searchModel->search(Yii::$app->request->queryParams);
return $this->render('index', [
'searchModel' => $searchModel,
'dataProvider' => $dataProvider,
]);
}
您可以使用查询参数,比方说“限制”,并将其输入索引页和其他页面。而不是在PersonsSearch模型的DataProvider构造中使用它。或使用“分页”属性。
$public $limit = null;
$query = Person::find();
if ($this->limit) {
$query->limit($this-limit)
}
$provider = new ActiveDataProvider([
'query' => $query,
'pagination' => [
'pageSize' => 20,
],
]);