Yii2:加载index.php时如何不填充GridView

问题描述 投票:0回答:1

我有一个用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,
    ]);
}
gridview yii2 pjax database-table
1个回答
0
投票

您可以使用查询参数,比方说“限制”,并将其输入索引页和其他页面。而不是在PersonsSearch模型的DataProvider构造中使用它。或使用“分页”属性。

$public $limit = null;

$query = Person::find();

if ($this->limit) {
    $query->limit($this-limit)
}

$provider = new ActiveDataProvider([
    'query' => $query,
    'pagination' => [
        'pageSize' => 20,
    ],
]);
© www.soinside.com 2019 - 2024. All rights reserved.