0

<select>複数の選択が可能な 70 近くのアイテムを含むアプリケーションがあります。

ユーザーがソースリストからターゲットリストにドラッグ/ドロップできる2つのリストでその動作を置き換えようとしています。最初の選択は、動きを反映する必要があります。

複数のページで動作を再利用する必要があるため、同じページで複数回再利用する必要があるため、汎用的にしようとしています。

私が今持っているもの(読みやすくするために実際のアイテム数を減らしました):

<div style="border: solid 1px red; overflow:auto">
    <select name="lst1" multiple="multiple" id="lst1" class="go">
        <option value="1">Element N°1</option>
        <option value="2">Element N°2</option>
        <option selected="selected" value="3">Element N°3</option>
        <option value="4">Element N°4</option>
        <option value="5">Element N°5</option>
    </select>
</div>

<script type="text/javascript">
    $(function () {
        $(".go").each(function (index, el) {
            var source = document.createElement("ul");
            var target = document.createElement("ul");
            $(el).after(source);
            $(el).after(target);
            $(source).addClass("sourceItems");
            $(target).addClass("targetItems");
            $(el + "option:selected").each(function (index2, sub) {
                var item = document.createElement("li");
                item.textContent = $(sub).text();
                $(target).append(item);
            });
            $(el + "option:not(:selected)").each(function (index2, sub) {
                var item = document.createElement("li");
                item.textContent = $(sub).text();
                $(source).append(item);
            });

            $(source).sortable({ connectWith : target});
            $(target).sortable({ connectWith : source });
        });
    });

</script>

<style type="text/css">    
.sourceItems, .targetItems { list-style-type: none; float:left; margin: 0; padding: 0; margin-right: 10px; background: #eee; padding: 5px; width: 200px; border: solid 1px black; } 
.sourceItems li, .targetItems li { margin: 5px; padding: 5px; width: 180px; height: 12px; cursor: move; }
</style>

このコードは予期しない結果を生成しています:

ここに画像の説明を入力

「ターゲット」リストの生成された DOM は ok のようになります。

<ul class="targetItems ui-sortable">
<li>Element N°3</li>
<li>Element N°7</li>
<li>Element N°8</li>
<li>Element N°14</li>
<li>Element N°20</li>
<li>Element N°15</li>
<li>Element N°21</li>
</ul>

しかし、「ソース」リストの生成された DOM は混乱しています (各要素にページ DOM が含まれています):

<li>
    .sourceItems, .targetItems { list-style-type: none; float:left; margin: 0; padding: 0; margin-right: 10px; background: #eee; padding: 5px; width: 200px; border: solid 1px black; } 
    .sourceItems li, .targetItems li { margin: 5px; padding: 5px; width: 180px; height: 12px; cursor: move; }
</li><li>

</li><li></li><li>
    .sourceItems, .targetItems { list-style-type: none; float:left; margin: 0; padding: 0; margin-right: 10px; background: #eee; padding: 5px; width: 200px; border: solid 1px black; } 
    .sourceItems li, .targetItems li { margin: 5px; padding: 5px; width: 180px; height: 12px; cursor: move; }

    Element N°1
    Element N°2
    Element N°3
    Element N°4
    Element N°5
    Element N°6
    Element N°7
    Element N°8
    Element N°9

...

Element N°3Element N°7Element N°8Element N°14Element N°15Element N°20Element N°21Element N°23Element N°27Element N°29Element.

何が悪いのかわかりません。誰かが問題の根本を指摘してくれれば幸いです。

問題を示す jsfiddle は次のとおりです: http://jsfiddle.net/gsYHb/

[編集]ソース要素とターゲット要素の作成順序を逆にすると、他のリストで問題が発生します:

        var source = document.createElement("ul");
        var target = document.createElement("ul");
        $(el).after(target);
        $(el).after(source);

この場合、これは乱雑なターゲット リストです。

4

1 に答える 1

0

http://jsfiddle.net/stevebeauge/gsYHb/6/でわかるように、私は自分の問題を解決することができました。

$(this + "option:not(:selected)")ページ全体を返していたのはセレクターによるものでした。

このコードを次のように置き換えると$(this).children("option:not(:selected)")、スクリプトが機能します(+その他のマイナーな修正)

于 2012-07-17T12:10:44.410 に答える