Сохранение данных из выпадающего списка select2 в Yii2 без активной формы

У меня есть модальное окно, содержащее раскрывающийся список, спрашивающий причину, по которой что-то было закрыто.

Нажав кнопку «Сохранить», я хотел бы, чтобы информация, выбранная в select2, обновляла модель, как в активной форме …

Вот код для модального окна:

<div class="modal fade close-modal" tabindex="-1" role="dialog" aria-labelledby="mySmallModalLabel" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
<h4 class="modal-title" id="myModalLabel">Reason for closure</h4>
</div>
<div class="modal-body">
<?php echo Select2::widget([
'model' => $model,
'attribute' => 'opportunity_closure_id',
'name' => 'closure-reason',
'options' => [
'limit' => 10,
],
'addon'=> [
],
'pluginOptions' => [
'allowClear' => true,
'ajax' => [
'url' => \Yii::$app->urlManager->createUrl('opportunity/closuredatalist'),
'dataType' => 'json',
'data' => new JsExpression($dataExp),
'results' => new JsExpression($dataResults),
],
'initSelection' => new JsExpression($initScriptClosure),
'multiple' => false
]
])?>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
<?php echo \yii\helpers\Html::a('<span class=""></span> Save', ['opportunity/close','id' => $model->id], ['class' => 'btn btn-primary'])?>
</div>
</div>
</div>
</div>

Любые идеи о том, как я могу это сделать?

0

Решение

попробуйте добавить type: "POST" AJAX позвонить

у меня ниже Ajax Call работает,

        $.ajax({
url: eduLevelCreateURL,
cache: false,
data: {"name":level.name,"shdesc":level.shdesc},
type: "POST",
timeout: 10000,
dataType: "json",
beforeSend: function (){
$("#progresBarUpload").addClass("active");
console.log(eduLevelCreateURL + " " + dataJ);
},
success: function (result) {
console.log(result);
var chtml = $("#person-educationid").html();
chtml+=result.data;
$("#person-educationid").html(chtml);
$('#newCat').modal('hide');
var value = result.value;
$("#person-educationid option[value='" + value + "']").attr("selected", "selected");

},

error: function (msg) {
alert("Error\n" + msg.toString());
}
});
0

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]