0

如果在下拉列表中选择了某个值,我试图隐藏一个 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>
4

1 回答 1

4

Method next selects exactly the next element. You'd better use siblings:

$(this).siblings('.selectNos').hide();

BTW, in order to get the selected value in your case you can use this.value instead of $('option:selected', this).text().

于 2012-07-03T13:00:35.453 回答