根据Multiselect选择显示/隐藏下拉列表

时间:2014-04-03 16:30:17

标签: javascript jquery

我有以下HTML。

<select id="segment_c" name="segment_c[]" multiple="true" size="6" style="width:150" title="" tabindex="0">
<option label="" value="" selected="selected"></option>
<option label="Mobile1" value="Mobile1">Mobile1</option>
<option label="Mobile2" value="Mobile2">Mobile2</option>
<option label="Mobile3" value="Mobile3">Mobile3</option>
</select>


<select name="Mobile1_c" id="Mobile1_c" title="">
<option label="" value=""></option>
<option label="Samsung" value="Samsung">Samsung</option>
<option label="Nokia" value="Nokia">Nokia</option>
</select>

<select name="Mobile2_c" id="Mobile2_c" title="">
<option label="" value="" selected="selected"></option>
<option label="Samsung" value="Samsung">Samsung</option>
<option label="Nokia" value="Nokia">Nokia</option>
</select>

<select name="Mobile3_c" id="Mobile3_c" title="">
<option label="" value=""></option>
<option label="Motorola" value="Motorola">Motorola</option>
<option label="Nokia" value="Nokia">Nokia</option>
</select>

这是多选列表

我在下面的jQuery中需要帮助。

我想迭代multiselect (id="segment_c"),以便value="Mobile1" value="Mobile2" value="Mobile3" < strong>已选择,然后显示id="Mobile1_c"以及id="Mobile2_c"id="Mobile3"

的下拉列表

基于多选中选择的值显示/隐藏下拉列表。

提前致谢。

约翰

2 个答案:

答案 0 :(得分:1)

请注意,来自多个select的值存储在数组中。

$(document).ready(function () {
    function hideAll() {
        $('#Mobile1_c,#Mobile2_c, #Mobile3_c').hide();
    }
    hideAll();

    $('#segment_c').change(function() {
        hideAll();
        var val = $(this).val();
        if (val == "") {
            hideAll();
        } else {
            for (var i = 0; i <= val.length; i++) {
                $('select[name*="' + val[i] + '"]').show();
            }
        }
    });

});

http://jsfiddle.net/4nuAW/2/

答案 1 :(得分:0)

@Freak_Droid几乎拥有它,但我无法评论缺乏代表。

使用该实现,您不需要按要求选择所有三个

$('#Mobile1_c,#Mobile2_c, #Mobile3_c').toggle();

$('#segment_c').change(function(){
    //val returns an array not a jquery object so dont prefix with a $
    var val = $(this).val();

    //you may want a more robust check here
    if(val.length === 3){
        $('#Mobile3_c').show();
    }else{
        $('#Mobile3_c').hide();    
    }
});

http://jsfiddle.net/VuN78/1