1
私の問題は、チェックボックスからデータを選択して保存ボタンをクリックしたときに、どこに行くのかわかりません。別のテーブルを作成するか、イベントテーブルに列を追加する必要がありますか。 これは、イベントの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();
}
}
誰かが私に問題の解決を手伝ってくれることを願っています。私は本当にそれを感謝しています。ありがとうございました。
は、実際の後、保存ボタンをクリックして、私はそれを保存するデータベース内のどのテーブルに思います。または、選択したチェックボックスデータの別のモデルを作成する必要がありますか? @Bizley – Fyp16
あなたが提供したコードに基づいて私はあなたに答えることができ、 'Events'クラスで設定したテーブルに保存しようとしているのが分かります。 – Bizley