0

ソート可能なリストを動的に作成しています。ただし、新しく作成されたリスト項目に対して .on('dblclick') アクションが機能しません。静的リストに対してのみ機能します。

$( "#sortable" ).sortable( "refresh" );  

リフレッシュも機能しないようです。
ここに私の完全なコードがあります

<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8" />
<title>jQuery UI Sortable - Default functionality</title>
<link rel="stylesheet" href="http://code.jquery.com/ui/1.10.3/themes/smoothness/jquery-ui.css" />
<script src="http://code.jquery.com/jquery-1.9.1.js"></script>
<script src="http://code.jquery.com/ui/1.10.3/jquery-ui.js"></script>
<link rel="stylesheet" href="/resources/demos/style.css" />
    <style>
    #sortable { list-style-type: none; margin: 0; padding: 0; width: 60%; }
    #sortable li { margin: 0 3px 3px 3px; padding: 0.4em; padding-left: 1.5em; font-size: 1.4em; height: 18px; }
    #sortable li span { position: absolute; margin-left: -1.3em; }
    </style>
    <script>
     $(document).ready(function () {
        $(function() {
            $( "#sortable" ).sortable();
            $( "#sortable" ).disableSelection();
        });
        var i = 10;
        $(window).load(function(){
            $('#btn_createList').click(function() {    
                $('.ul_current').append('<li id="foo_' + i + '" class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>' + i);
                i++;
            $( "#sortable" ).sortable( "refresh" );
            });
        }); 
        $("#sortable li").on('dblclick',function(){
            alert($(this).attr('id'));
        });
}); 
    </script>

</head>
<body>

 <ul id="sortable" class="ul_current">
    <li id="foo_1" class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 1</li>
    <li id="foo_2" class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 2</li>
    <li id="foo_3" class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 3</li>

</ul>

 <button id="btn_createList">add</button>

</body>
</html>

前もって感謝します

4

2 に答える 2

2

あなたの問題は、そのイベントを受け取る準備ができていない要素にイベントをアタッチしていることです。イベントを親要素に添付する必要があります。その後、 をフィルタリングできます#sortable li。このようにして、クリック可能な要素がいつ追加されても問題なく機能します。これは、イベント委任と呼ばれます。イベントを処理するタスクを別の要素に委任しています。

そしてあなたのJS:

$("#sortable").on("dbclick", "li", function() {
    alert('it works!');
});

また、これを行うときは、ツリーの高すぎる親にアタッチしないでください。可能な限り最も近い親要素 (この場合は#sortable) にアタッチします。documentどの要素がこのイベントを取得するかを特定することをお勧めします。にアタッチするとdocument、 を持つすべての要素liがクリック可能になり、同じコードに応答することになります。異なるボタンに異なる機能を持たせたい場合、それらはすべて に接続された同じコードに応答しているため、それはできませんdocument

于 2013-09-16T17:39:33.750 に答える
2

イベント委譲を使用して、動的に作成されたlisにイベントをバインドします。

   $("#sortable").on('dblclick','li', function(){
        alert($(this).attr('id'));
    });

フィドル

または、$( "#sortable" ).sortable( "refresh" );要素が追加された後に行っているのと同じ方法で、追加された要素のイベントを次のようにバインドします。

$('#btn_createList').click(function () {

         var $li = $('<li/>', {
             id: 'foo_' + i,
                 'class': 'ui-state-default'
         }).on('dblclick', handleDblClick).append($('<span/>', {
             'class': 'ui-icon ui-icon-arrowthick-2-n-s'
         })).append(i);

         $('.ul_current').append($li);
         i++;
         $("#sortable").sortable("refresh");
     });

     $("#sortable li").on('dblclick', handleDblClick);

フィドル

于 2013-09-16T17:36:34.563 に答える