如何在 Yii2 中使用 kartik-Select2 小部件项目将所选项目保存到数据库?
How to save selected with kartik-Select2 widget items to DB in Yii2?
我的问题如下。
我正在尝试将多个项目插入 mysql 数据库 table。我为项目 selection 使用 Kartik-Select2 小部件。
以下代码对我有用,我可以使用它 select 多个项目。
<?= $form->field($model, 'categories')->widget(Select2::className(), [
'data' => $model->availableCategories(),
'model' => $model,
'attribute' => 'categories',
'language' => 'en',
'options' => ['placeholder' => 'Select a site...'],
'pluginOptions' => [
'allowClear' => true,
'multiple' => true,
],
]) ?>
但是现在如何将 selected 项目保存到数据库 table。 selected 项目存储在哪里(小部件内是否有一些数组)?
我的 'categories' 属性在模型 class 中定义为:
public $categories = [];
我认为 selected 项目会填充到它。但它不起作用(表单提交后数组为空)。我阅读了许多类似的主题,但没有找到完整和完整的解释它是如何工作的。我是 Yii2 的新手,可能迷路了。感谢您的帮助。
通常多个 select 项目以这种方式保存(这是一种简化的方式)
public function actionYourAction()
{
$post = Yii::$app->request->post();
if (!empty($post)){
$postModel = $post['YourModel'];
$postModelMulti= $postModel['your_multi_attribute'];
if ( !empty( $postModelMulti) ){
foreach ($postModelMulti as $key => $value) {
$newModel = new YuorModelToAdd();
$newModel->your_attribute = $value;
$newModel->save();
}
}
}
......
我的问题如下。 我正在尝试将多个项目插入 mysql 数据库 table。我为项目 selection 使用 Kartik-Select2 小部件。 以下代码对我有用,我可以使用它 select 多个项目。
<?= $form->field($model, 'categories')->widget(Select2::className(), [
'data' => $model->availableCategories(),
'model' => $model,
'attribute' => 'categories',
'language' => 'en',
'options' => ['placeholder' => 'Select a site...'],
'pluginOptions' => [
'allowClear' => true,
'multiple' => true,
],
]) ?>
但是现在如何将 selected 项目保存到数据库 table。 selected 项目存储在哪里(小部件内是否有一些数组)? 我的 'categories' 属性在模型 class 中定义为:
public $categories = [];
我认为 selected 项目会填充到它。但它不起作用(表单提交后数组为空)。我阅读了许多类似的主题,但没有找到完整和完整的解释它是如何工作的。我是 Yii2 的新手,可能迷路了。感谢您的帮助。
通常多个 select 项目以这种方式保存(这是一种简化的方式)
public function actionYourAction()
{
$post = Yii::$app->request->post();
if (!empty($post)){
$postModel = $post['YourModel'];
$postModelMulti= $postModel['your_multi_attribute'];
if ( !empty( $postModelMulti) ){
foreach ($postModelMulti as $key => $value) {
$newModel = new YuorModelToAdd();
$newModel->your_attribute = $value;
$newModel->save();
}
}
}
......