0

同じ要素の 3 つのドロップダウン リストがあります。最初のリストで選択された値は、2 番目のドロップダウン リストに表示されません。2 番目のリストで選択された値は、3 番目のドロップダウン リストには表示されません。jqueryを使用してそれを行う方法は?

4

3 に答える 3

2

デモをご覧ください: http://jsfiddle.net/ezKDB/

Jquery プラグイン: https://github.com/WilliamHuey/mutually_exclusive_list_jquery

使用法:

$('select.classNameForEachList').onlyBeOne();
于 2012-09-24T05:33:32.860 に答える
0

次に例を示します。

HTML

<select class="sel-1">
    <option value="1">One</option>
    <option value="2">Two</option>
    <option value="3">Three</option>
</select>


<select class="sel-2">
    <option value="1">One</option>
    <option value="2">Two</option>
    <option value="3">Three</option>
</select>


<select class="sel-3">
    <option value="1">One</option>
    <option value="2">Two</option>
    <option value="3">Three</option>
</select>

jQuery

var allSelects = $('select[class^=sel-]');
allSelects.on('change', function() {
  allSelects.find('options').show();
  allSelects.not(this).find('option[value="'+ this.value +'"]').hide();
});

動作デモ

これがあなたにアイデアを与えることを願っています。

于 2012-09-17T08:21:18.527 に答える
0

可能な解決策は次のとおりです。

<html>
<body>
<select id="first" data-child="#second">
<option value="1">one</option>
<option value="2">two</option>
<option value="3">three</option>
<option value="4">four</option>
<option value="5">five</option>
<option value="6">six</option>
<option value="7">seven</option>
</select>

<select id="second" data-child="#third">
</select>

<select id="third">
</select>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.8.1/jquery.min.js"></script>
<script type="text/javascript">

$(document).ready(init);

function mapItems(index, elem){
    var items = [];
    items.push({value:$(elem).val(), text:$(elem).text()});    
    return items;
}

function replaceItems(items, appendTo){
    appendTo.empty();
    for(var i in items){
        var item = items[i];
        if(item.value && item.text){
            appendTo.append("<option value='"+item.value+"'>"+item.text+"</option");
        }
    }
}

function selected(e){        
    var items = $(this).find("option:not(:selected)").map(mapItems);
    var child = $($(this).attr("data-child"));
    replaceItems(items, child);
    child.change();
}

function init(){
    var first = $("select#first");    
    var second = $("select#second");    
    var third = $("select#third");
    first.change(selected);
    second.change(selected);
    first.trigger('change');
}​
</script>
</body>
</html>

あまりきれいではありませんが、機能します。ここでデモを参照してください。

更新コードをクリーンアップしました。これは最終バージョンへのリンクです: http://jsfiddle.net/goranobradovic/JLMJn/2/

更新 2ここにすべての html を配置しました。空の html ファイルにコピーするだけで機能します。

于 2012-09-17T08:34:11.610 に答える