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

Yii2:加载index.php时如何不填充GridView,gridview,yii2,pjax,database-table,Gridview,Yii2,Pjax,Database Table,我有一个用Gii代码生成器生成的index.php文件。它有一个GridView,其中包含数据库表的数据。它有536000行,因此移动速度非常慢。有时甚至超过30秒,因此根本不加载页面 我想用空的GridView(或没有GridView)启动我的索引文件(),当用户使用\u search.php文件的过滤器时,它可以被填充 My index.php文件: <? Pjax::begin() ?> <? echo $this->render('_search', ['mode

我有一个用Gii代码生成器生成的
index.php
文件。它有一个GridView,其中包含数据库表的数据。它有536000行,因此移动速度非常慢。有时甚至超过30秒,因此根本不加载页面

我想用空的GridView(或没有GridView)启动我的索引文件(),当用户使用
\u search.php
文件的过滤器时,它可以被填充

My index.php文件:

<? Pjax::begin() ?>
<? echo $this->render('_search', ['model' => $searchModel]) ?>

<?= GridView::widget([
    'dataProvider' => $dataProvider,
    'filterModel' => $searchModel,
    'columns' => [
        'id',
        'name',
        'details',
    ],
]) ?>
<? Pjax::end() ?>
<?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() ?>
public function actionIndex()
{
    $searchModel = new PersonsSearch();
    $dataProvider = $searchModel->search(Yii::$app->request->queryParams);

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

您可以使用查询参数,比如“limit”,并在索引页面和其他页面上提供它。然后在PersonSearch模型的DataProvider构造中使用它。 或者使用“分页”属性

public $limit = null;

public function search()
{

    $query = Person::find();

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

    $provider = new ActiveDataProvider([
        'query' => $query,
        'pagination' => [
            'pageSize' => 20,
        ],
    ]);

    return $provider;
}

您可以尝试将这段代码移动到另一个
php
文件中,并在controller中创建一个函数,该函数将在ajax或post-request呈现的gridview上返回。然后嵌入正确的位置。应在文档就绪状态下调用此函数。但从理论上讲:)只是一个尝试。或者像添加示例一样,我会传递(如果这不是ajax或post请求,或者等于null)一个属性为limit of the modal的数组,比如等于10,所以基本上显示10条乞讨记录,但其余的都是客户要求的。你是否也在搜索表单中使用gridview过滤器?@MuhammadOmerAslam:是的。这是个坏主意吗?