次のように、提供された ajax コールバック関数を使用して郵便番号を取得するために、jQuery select2 プラグインを使用します。
$(document).ready(function() {
$("#postcodes").select2({
placeholder : "Search for a postcode",
multiple : true,
minimumInputLength : 3,
ajax : {
url : "/bignibou/utils/findGeolocationPostcodeByPostcodeStartingWith.json",
dataType : 'json',
data : function(term) {
return {
postcode : term
};
},
results : function(data) {
console.log(data);
return {
results : $.map(data, function(item) {
return {
id : item.id,
text : item.postcode
};
})
};
}
}
});
});
hidden input
2 つの郵便番号が選択されると、DOMで結果が得られます。
<input type="hidden" class="bigdrop select2-offscreen" id="postcodes" style="width:600px" name="familyAdvertisement.postcodes" value="4797,4798" tabindex="-1">
私が抱えている問題は、フォームが再表示されると (たとえば、他のコントロールがエラーになっている場合)、選択 (つまり、2 つの郵便番号と特にtext
) がフォームに表示されないことですhidden input
。値 (つまり、郵便番号の s である 4797 と 4798 id
)。
フォームが再表示されたときに別の ajax ラウンドトリップを行う必要があるかどうか、またはより良い方法があるかどうかはわかりません。
誰でもアドバイスできますか?