如果在下拉列表中选择了某个值,我正在尝试隐藏div。我正在使用
$(this).next('.selectNos').hide();
但由于某种原因,它不会完成这项工作。请有人指出我做错了吗?
$(document).ready(function() {
$('#addCondition').on('change','.conOperatorC', function(e){
if ($('option:selected',this).text() == "In" || $('option:selected',this).text() == " Not In") {
alert($('option:selected',this).text());
$(this).next('.selectNos').hide();
}
else {
$(this).next(':select').hide();
}
});
$('.conOperatorC').trigger('change');
});
<div id="addCondition">
<select id="conOperator0" name="conOperator0" class="standard_select conOperatorC" style="width:147px;">
<option>blah</option><option>
<option>Contains</option>
<option>In</option>
<option>Not In</option>
</select>
<input type="text" id="conValue0" name="conValue0" class="short_input" value="" style="width:147px;">
<div class="selectNos">
<select id="conValuedd0" multiple="multiple" size="5" style="display: none; ">
<option value="option1">blah</option>
<option value="option2">blah</option>
</select>
<button type="button" class="ui-multiselect ui-widget ui-state-default ui-corner-all" aria-haspopup="true" tabindex="0" style="width: 225px; "><span class="ui-icon ui-icon-triangle-2-n-s"></span><span>Please Select</span></button>
</div>
</div>
答案 0 :(得分:4)
方法next
完全选择下一个元素。你最好使用siblings
:
$(this).siblings('.selectNos').hide();
顺便说一句,为了获得您所选择的值,您可以使用this.value
代替$('option:selected', this).text()
。