laravel jquery select2 multiselect - 初始化所选元素

时间:2017-06-06 07:47:23

标签: javascript php laravel laravel-5.2 jquery-select2

大家早上好,我试图将初始选择的选项(通过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 "";
}
你可以对此有所了解吗? 提前谢谢。

3 个答案:

答案 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下拉列表。