Yii2: как не заполнять GridView при загрузке index.php

У меня есть файл index.php, созданный с помощью Gii Code Generator. У него есть 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() ?>

Мой файл personController.php:

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

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

person Roby Sottini    schedule 05.06.2020    source источник
comment
Вы можете попробовать переместить этот кусок кода в другой php файл и создать функцию в контроллере, которая будет возвращать ajax или отправлять запрос на визуализацию gridview. затем вставьте в нужное место. эту функцию следует вызывать в состоянии готовности документа. Но это в теории :) просто попробовать.   -  person Serghei Leonenco    schedule 06.06.2020
comment
Или, как пример добавления, я бы передал (если это не ajax или почтовый запрос или равен нулю) массив со свойствами предела модального типа, равным 10, поэтому вы в основном отображаете 10 записей из попрошайничества, но остальные какой бы ни был запрос клиента.   -  person Serghei Leonenco    schedule 06.06.2020
comment
Вы используете фильтры gridview вместе с формой поиска?   -  person Muhammad Omer Aslam    schedule 06.06.2020
comment
@MuhammadOmerAslam: Да. Это плохая идея?   -  person Roby Sottini    schedule 06.06.2020


Ответы (1)


Вы можете использовать параметр запроса, скажем, «лимит» и передавать его на странице индекса и на других. А затем использовать его в конструкции DataProvider в модели PersonsSearch. Или используйте свойство «pagination».

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;
}
person Alex    schedule 06.06.2020