我正在动态创建一个可排序的列表。但是 .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>
提前致谢