大家早上好,我试图将初始选择的选项(通过ajax请求)设置为jquery select2(多选)时卡住了。如果我使用控件,多选工作正常。当我必须编辑以前保存的模型时会出现问题,因为我之前选择的选项都没有显示出来。
这是我的观点:
<div class="form-group {{ $errors->has('pubblicazione_giuridica_id') ? 'has-error' : ''}}">
{!! Form::label('pubblicazione_giuridica_id', 'Law Pubs', ['class' => 'col-sm-3 control-label']) !!}
<div class="col-sm-6">
{!! Form::select('pubblicazione_giuridica_id[]', [$pubGiurList], null, ['class' => 'form-control', 'id'=>'select-pgiur', 'multiple'=>'multiple']) !!}
{!! $errors->first('pubblicazione_giuridica_id', '<p class="help-block">:message</p>') !!}
</div>
javascript:
$('#select-pgiur').select2({
ajax: {
url: "{!! URL::to('/gare/proc-getpubgiur') !!}",
dataType: 'json',
delay: 150,
data: function (params) {
return { q: params.term, };
},
processResults: function (data, params) {
return { results: data.items, };
},
cache: true
},
language: 'it',
theme: "bootstrap",
placeholder: "Choose an option."
});
控制器:
public function edit($id, Request $request) {
$procedure = $this->getProcedure($id, $request, true);
if (!$procedure) {
return redirect('gare/procedure')->with('alert-warning', 'Gara non trovata - Operazione non consentita');
}
return view('gare.procedures.edit', [ 'procedure'=>$procedure, 'opChoiceList'=>$this->getOpChoiceList(), 'pubGiurList'=>json_encode(GaraPubblicazioneGiuridica::GetPubByGaraId($procedure->id)) ]);
}
型号:
public static function GetPubByGaraId($id){
//TODO: visualizzare le selected publications
$procagg = GaraPubblicazioneGiuridica::where('gara_id','=',$id)->select('id')->get();
if($procagg){
$plucked = $procagg->pluck('nome');
$toReturn = array();
foreach($plucked as $key=>$value){
$toReturn[$key]=$value;
}
return $toReturn;
}
return "";
}
你可以对此有所了解吗?
提前谢谢。
答案 0 :(得分:0)
您可以在J-query事件上创建一个ajax调用,并通过id绑定数据。
。<强> $( “#选择-pgiur”)VAL(data.items).trigger( “变化”); 强>
也许它可以帮助你......
答案 1 :(得分:0)
如果我正确理解了您的最终目标,您希望在使用从Ajax请求收到的数据初始化之后,通过选择选项来更新Select2多选。
如果是这种情况,那么您正在寻找.trigger('change')
事件。
我个人使用VueJS和手工制作的表格,但这应该指向正确的方向:
$("#your_select2_id").val(selected_values_array).trigger("change");
selected_values_array
是一个JS数组,其中包含您想要选择的值:<option value="1"></option>
。 .trigger()
然后更新Select2以显示它们。
希望有所帮助!
答案 2 :(得分:0)
制作下拉选择器时,您可以指定最初选择的选项:
Form::select(
'pubblicazione_giuridica_id[]',
[$pubGiurList],
$opChoiceList,
['class' => 'form-control', 'id'=>'select-pgiur', 'multiple'=>'multiple']
)
但是,这意味着您需要使用最初选择的选项预先填充AJAX select2下拉列表。