当我试图隐藏div时,Jquery .next()不起作用

时间:2012-07-03 12:58:32

标签: javascript jquery

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

1 个答案:

答案 0 :(得分:4)

方法next完全选择下一个元素。你最好使用siblings

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

顺便说一句,为了获得您所选择的值,您可以使用this.value代替$('option:selected', this).text()