Chosen 플러그인을 사용하여 선택에서 현재 선택된 옵션을 변경하려고합니다.
문서 덮개 목록을 업데이트하고, 외부 현재 선택된 값을 변경상의 옵션을 선택한 경우, 아무것도하지만, (나는 볼 수) 트리거링.
코드 와 선택 항목을 변경하는 방법 을 보여주기 위해 jsFiddle을 만들었습니다 .
$('button').click(function() {
$('select').val(2);
$('select').chosen().val(2);
$('select').chosen().select(2);
});
답변
문서의 “선택한 항목을 동적으로 업데이트”섹션에서 : 필드에서 ‘chosen : updated’이벤트를 트리거해야합니다.
$(document).ready(function() {
$('select').chosen();
$('button').click(function() {
$('select').val(2);
$('select').trigger("chosen:updated");
});
});
참고 : 1.0 이전 버전은 다음을 사용했습니다.
$('select').trigger("liszt:updated");
답변
내 답변은 늦었지만 위의 모든 답변에서 누락 된 정보를 추가하고 싶습니다.
1) 선택한 선택에서 단일 값을 선택하려면.
$('#select-id').val("22").trigger('chosen:updated');
2) 다중 선택 선택을 사용하는 경우 한 번에 여러 값을 설정해야 할 수도 있습니다.
$('#documents').val(["22", "25", "27"]).trigger('chosen:updated');
다음 링크에서 수집 된 정보 :
1) 선택한 문서
2) 선택한 Github 토론
답변
때때로 선택한 옵션을 조작하기 위해 현재 옵션을 제거해야합니다.
다음은 옵션을 설정하는 방법의 예입니다.
<select id="mySelectId" class="chosen-select" multiple="multiple">
<option value=""></option>
<option value="Argentina">Argentina</option>
<option value="Germany">Germany</option>
<option value="Greece">Greece</option>
<option value="Japan">Japan</option>
<option value="Thailand">Thailand</option>
</select>
<script>
activateChosen($('body'));
selectChosenOptions($('#mySelectId'), ['Argentina', 'Germany']);
function activateChosen($container, param) {
param = param || {};
$container.find('.chosen-select:visible').chosen(param);
$container.find('.chosen-select').trigger("chosen:updated");
}
function selectChosenOptions($select, values) {
$select.val(null); //delete current options
$select.val(values); //add new options
$select.trigger('chosen:updated');
}
</script>
JSFiddle (하우투 추가 옵션 포함) :
https://jsfiddle.net/59x3m6op/1/
답변
선택 유형 이 여러 개인 경우 및 / 또는 이미 선택한 항목을 하나씩 드롭 다운 목록 항목 내에서 직접 제거하려면 다음과 같이 사용할 수 있습니다.
jQuery("body").on("click", ".result-selected", function() {
var locID = jQuery(this).attr('class').split('__').pop();
// I have a class name: class="result-selected locvalue__209"
var arrayCurrent = jQuery('#searchlocation').val();
var index = arrayCurrent.indexOf(locID);
if (index > -1) {
arrayCurrent.splice(index, 1);
}
jQuery('#searchlocation').val(arrayCurrent).trigger('chosen:updated');
});