2016-11-23 5 views
1

私の問題は、チェックボックスからデータを選択して保存ボタンをクリックしたときに、どこに行くのかわかりません。別のテーブルを作成するか、イベントテーブルに列を追加する必要がありますか。 enter image description here これは、イベントのindex.phpのコーディングです。チェックボックスから選択したデータをデータベースに保存する方法

<?php 

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

    /* @var $this yii\web\View */ 
    /* @var $dataProvider yii\data\ActiveDataProvider */ 

    $this->title = 'Events'; 

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

    <div class="events-index"> 

     <h1><?= Html::encode($this->title) ?></h1> 
     <p> 
      <?= Html::a('Create Events', ['create'], ['class' => 'btn btn- success']) ?> 
     </p> 
     <?= GridView::widget([ 
      'dataProvider' => $dataProvider, 
      'columns' => [ 
       ['class' => 'yii\grid\SerialColumn'], 


       'event_title', 
       'event_date', 
       'event_location:ntext', 

       ['class' => 'yii\grid\ActionColumn'], 
       ['class' => 'yii\grid\CheckBoxColumn'], 
      ], 
     ]); ?> 
     <?=Html::beginForm(['events/bulk'],'post');?> 

    <center><?=Html::submitButton('Save', ['class' => 'btn btn-info',]);?> </center> 
    <?= Html::endForm();?> 



    </div> 

これはeventscontroller.phpのアクションバルク用のコードです。私はyii2の新機能ですので、この次のコードを編集する方法はわかりません。selectイベントの後に保存ボタンをクリックすると、データベースに保存されます。

 public function actionBulk() 
     { 

     $selection=(array)Yii::$app->request->post('selection');//typecasting 
     foreach($selection as $id){ 
      $e=Events::findOne((int)$id);//make a typecasting 
      //do your stuff 
      $e->save(); 
     } 
     } 

誰かが私に問題の解決を手伝ってくれることを願っています。私は本当にそれを感謝しています。ありがとうございました。

答えて

0

ではなく、テーブルキーの機種IDを返すことができますので、このチェックボックス列のGridViewの設定を変更します。

[ 
    'class' => 'yii\grid\CheckBoxColumn', 
    'checkboxOptions' => function ($model, $key, $index, $column) { 
     return ['value' => $model->id]; 
    }, 
], 
+0

は、実際の後、保存ボタンをクリックして、私はそれを保存するデータベース内のどのテーブルに思います。または、選択したチェックボックスデータの別のモデルを作成する必要がありますか? @Bizley – Fyp16

+0

あなたが提供したコードに基づいて私はあなたに答えることができ、 'Events'クラスで設定したテーブルに保存しようとしているのが分かります。 – Bizley

関連する問題