无法动态拖动附加DIV

时间:2013-08-31 07:14:04

标签: javascript jquery html drag

http://liveweave.com/rh0ILM

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>');
    });
});

3 个答案:

答案 0 :(得分:3)

尝试以下方法。您必须使用委托,因为DIV是动态创建的。

$('.container').on('drag','.drag',(function( ev, dd ){
    $( this ).css({
        top: dd.offsetY,
        left: dd.offsetX
    });
}));

Working Demo

答案 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.
    });
});