Yii2 pjax.reload不适用于gridview记录更新

时间:2017-02-21 07:42:53

标签: javascript php jquery yii2 pjax

我为网格视图开发了每页行数功能。下拉列表有5,10,25,50,100等选项。我需要更改任何下拉选项,以显示网格视图的选定行数。为此我创建了一个Pjax容器,其网格视图如下:

    <?php
  session_start();
  if (empty($_SESSION['id'])) {
    $_SESSION['errMsg'] = '<div class="alert alert-danger" role="alert">
    <strong>Post:</strong> You must be logged in `enter code here`in order to post.
    </div>';
    header('Location: ../../index.php');
    exit;
  }
?>

_search.php看起来像:

<?php

use yii\helpers\Html;
use yii\grid\GridView;
use yii\widgets\Pjax;

$this->title = 'Test Cards';
$this->params['breadcrumbs'][] = $this->title;
?>

<div class="row">
    <div class="test-card-index">
        <?= $this->render('_search', [ 'model' => $searchModel ]) ?>   
    </div>
</div>

<?php Pjax::begin(['id' => 'test_grid_pjax', 'enablePushState' => false, 'timeout' => 1000000]); ?> 

<div class="row">
<?= GridView::widget([
    'dataProvider' => $dataProvider,
    'class' => 'table table-bordered responsive',
    'id' => 'test_grid',
    'summary' => "<div class='summary'><label>Showing {begin} - {end} of {totalCount} items.</label></div> <div class='col-sm-6 pageDropdown'> <label>Records per page</label>  ".Html::dropDownList('pageSize', (int) Yii::$app->session->get('pageSize', Yii::$app->params['defaultPageSize']), Yii::$app->params['rowPerPage'], ['id' => 'pageSize', 'class' => 'form-control', 'onchange' => 'return reloadGrid("test_grid_pjax",this.value)']) . "</div>",
    'layout' => '{summary}{items}<div class="pager">{pager}</div>',
    'options' => ['class' => 'main-grid grid-view full-table'],
    'columns' => [
        'cc_amount',
        'cc_number',                    
        'cc_type',
        'cc_status'
        ],
    ]);
?>
</div>

<?php Pjax::end(); ?>
Controller中的

动作如下:

<?php
use yii\helpers\Html;
use yii\widgets\ActiveForm;
?>

<div class="test-card-search">

    <?php $form = ActiveForm::begin([
    'action' => ['index'],
    'method' => 'get',
    'options' => ['data-pjax' => true , 'class'=>'search_form form-horizontal' ]

]); ?>

<div class="form-group">
    <div class="row">
        <div class="col-md-6">
            <?= Html::activeLabel($model, 'cc_number',['class'=>'control-label col-sm-5']); ?>
            <div class="col-sm-6">
                <?= Html::activeTextInput($model, 'cc_number', ['class'=>'form-control col-sm-5','autofocus'=>true]); ?>                                
            </div>
        </div>
    </div>
</div>

<div class="form-group"> 
    <div class="row">
        <div class="col-md-6">
            <?= Html::activeLabel($model, 'cc_type',['class'=>'control-label col-sm-5']); ?>
            <div class="col-sm-6">                                
                <?= Html::activeDropDownList($model, 'cc_type',[ "RESTRICTED" => Yii::t('app','RESTRICTED'), "UNRESTRICTED" => Yii::t('app','UNRESTRICTED')],['prompt' => Yii::t('app','All Types'), 'class'=>'form-control col-sm-5']); ?>                                
            </div>
        </div>
    </div>
</div>

<div class="form-group">
    <div class="col-md-5"></div>

    <div class="col-md-3">
        <div class="form-group">
            <?= Html::submitButton('Search', ['class' => 'btn btn-blue']) ?>
            &nbsp;&nbsp;&nbsp;
            <?= Html::resetButton('Reset', ['class' => 'btn btn-primary','id'=>'resetButton','onclick'=>"location.href = '".Yii::$app->urlManager->createUrl('testcard/index')."';"]) ?>
        </div>
    </div>
</div>  

<?php ActiveForm::end(); ?>

</div>

函数reloadGrid()就像:

public function actionIndex()
{

    if (Yii::$app->request->get('pageSize')) {
        Yii::$app->session->set('pageSize', (int) Yii::$app->request->get('pageSize'));
    }

    // to set the selected page number of the grid
    if (Yii::$app->request->get('page')) {
        Yii::$app->session->set('page',(int)Yii::$app->request->get('page'));
    } else {
        Yii::$app->session->set('page',1);
    }

    $searchModel = new TestCardSearch();
    $dataProvider = $searchModel->search(Yii::$app->request->queryParams);

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

在搜索任何字段时,它会重新加载整个页面,并在url中设置搜索参数。 另一个问题是,在更改'pageSize'下拉列表时,它仅适用于第一次,在其他每次尝试时都会在控制台中显示错误,如:

<script type='text/javascript'>
function reloadGrid(id, value, url) {
$.pjax.reload({
    container: "#" + id,
    data: $('#search_form').serialize() + "&pageSize=" + value,
    url: url,
    push: false,
    replace: false,
    timeout: 1000000
});
}
</script>

这是JS冲突的问题吗? 我通过谷歌搜索尝试了许多解决方案,但没有得到它。

1 个答案:

答案 0 :(得分:0)

我遇到了一个类似的问题,即pjax没有解析网格过滤器中的所有搜索字段。我的解决方案/变通方法/黑客是触发网格过滤器字段的更改事件,而不是直接调用pjax重新加载。

        $('.date-range-filter').trigger('change'); // this works

        /*  // this didn't parse all the values from my form 
        $.pjax.reload({
            container: "#grid-pjax"
        });
        */

它与gridView收集提交的表单值的方式有关。它实际上为网格列过滤器构建了一个新的虚拟表单,因为gridview的标题过滤器没有实际的表单

在您的情况下,您还应检查来源并确保表格正确无误

    <?php $form = ActiveForm::begin([
    'action' => ['index'],
    'method' => 'get',
    'id'=> 'myFormId' // <---- try giving the form an id
    'options' => ['data-pjax' => true , 'class'=>'search_form form-horizontal' ]

]); ?>

您也可以尝试使用pjax小部件表单选择器属性 - 而不是pjax开始和结束。这将让pjax自动获取该表单中的所有输入字段。

<?php
Pjax::widget([
    'id' => 'search-form', 
    'enablePushState' => false, 
    'enableReplaceState' => false, 
    'formSelector' => '#myFormId', // <-- the form to submit with pjax
    // 'submitEvent' => 'change', /// whatever you want 
    ]);
 ?>