Yii2:加载index.php时如何不填充GridView
我有一个用Gii代码生成器生成的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
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:是的。这是个坏主意吗?