http://jsbin.com/IZodOSU/1/edit
具有拖拽类的所有div都应该是可拖动的,但是当附加一个div时它不可拖动。任何人都可以帮我解决这个问题吗?
HTML
<script src="http://threedubmedia.com/inc/js/jquery-1.7.2.js"></script>
<script src="http://threedubmedia.com/inc/js/jquery.event.drag-2.2.js"></script>
<script src="http://threedubmedia.com/inc/js/jquery.event.drag.live-2.2.js"></script>
<button id="divgen">Gen Div</button>
<div class="container">
<div class="drag" style="left:20px;"></div>
<div class="drag" style="left:100px;"></div>
<div class="drag" style="left:180px;"></div>
</div>
CSS
.drag {
position: absolute;
border: 1px solid #89B;
background: #BCE;
height: 58px;
width: 58px;
cursor: move;
top: 120px;
}
JS / JQuery的
jQuery(function($){
$('.drag').drag(function( ev, dd ){
$( this ).css({
top: dd.offsetY,
left: dd.offsetX
});
});
$("#divgen").click(function() {
$("div.container").append('<div id="whatever" class="drag">my div</div>');
});
});
答案 0 :(得分:3)
尝试以下方法。您必须使用委托,因为DIV是动态创建的。
$('.container').on('drag','.drag',(function( ev, dd ){
$( this ).css({
top: dd.offsetY,
left: dd.offsetX
});
}));
答案 1 :(得分:0)
由于这个div新添加到DOM中,在$(“#divgen”)中。单击(....),你需要重新运行拖动功能。
答案 2 :(得分:0)
添加新div后再次调用拖动功能。
jQuery(function($){
$('.drag').drag(function( ev, dd ){
$( this ).css({
top: dd.offsetY,
left: dd.offsetX
});
});
$("#divgen").click(function() {
$("div.container").append('<div id="whatever" class="drag">my div</div>');
$('.drag').drag(); // Call drag function.
});
});