复选框列不在使用模态的yii2 gridview中工作

时间:2016-06-09 10:17:50

标签: php gridview checkbox yii2

我有一个gridview。它显示了大学里可用的部门。 当我单击该行时,它会填充模态,并显示可用于kartik gridview中所选部门的讲师。

因为我正在使用kartik / grid / CheckboxColumn。

但是当我单击Checkbox并通过javacript获取所选行时,它不会返回与记录关联的主键。 如果我在没有模态的情况下执行gridview,那么它可以正常工作

           $this->registerJs("     
           $('#lect-logout').click(function() {
           var key = $('#w0-container').yiiGridView('getSelectedRows');
    alert(key);                                                                                                                                   
$.post(          
    '?r=lec-logout/logout',         
    {       
        id: $('#w0').yiiGridView('getSelectedRows'),
          },  
    function (data) {
        alert("ok");

    }   
);      

});
    “);

如何使用该模式的复选框。即使我单击复选框中的选择所有选项。它不会选择所有行。

控制器代码

     public function actionIndex()
    {
            $searchModel = new CollegeSearch();
            $dataProvider =    $searchModel->search(Yii::$app->request->queryParams);
            return $this->render('index', [ 'searchModel' => $searchModel,  'dataProvider' => $dataProvider]);                                    
    }

   public function actionLecture()                                                                                                               
    {
            $model = new Accounts();
            if ($model->load(Yii::$app->request->post())) {
            return $this->redirect(['index']);
            }
            else{
            $searchModel = new LectureSearch();
            $dataProvider = $searchModel->search(Yii::$app->request->queryParams);

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

查看代码

的index.php

        <?= GridView::widget([
            'dataProvider' => $dataProvider,
            'rowOptions' => function($model, $key, $index, $grid) {
            return ['id' => $model['account_id'], 'onclick' => 'getrow(this.id)'];
    },
            'columns' => [
            'displayname',
            ],
            ]); ?>

   <?php Modal::begin([
'id' => 'show-agents-modal',
    'size' => 'modal-lg',
'header' => '<h4 class="modal-title">View</h4>',
   ]);
      Modal::end(); ?>

Lecture.php

       <div class="pull-right">
      <?= Html::Button('Logout',['class'=>'btn btn-primary','id'=>'lect- logout']); ?>
     </div>
   <br>
        <?= GridView::widget([
    'dataProvider' => $dataProvider,
      //        'filterModel' => $searchModel,
    'columns' => [

         'first_name,

        ['class' => 'kartik\grid\CheckboxColumn'],
    ],
]); ?>

1 个答案:

答案 0 :(得分:0)

如果您想使用yii\grid\CheckboxColumn,请尝试以下操作:

<?= GridView::widget([
        'dataProvider' => $dataProvider,
        'columns' => [
            ['class' => 'yii\grid\SerialColumn'],

            [
                'class' => 'yii\grid\CheckboxColumn', 
                'checkboxOptions' => function($model, $key, $index, $column) {
                    return ['value' => $model->your_id];
                },
            ],
         .
         .
])?>