jQuery UI Multiple Droppable - 拖动整个div元素&克隆

时间:2012-10-24 19:35:52

标签: jquery-ui draggable droppable

我刚刚开始使用jQuery UI将div拖动到表格中的列中。我有几个不同的可拖动div,里面有不同的背景颜色和文字,我需要它们能够作为克隆拖到掉落区域。这通过使用jQuery UI的示例购物车代码工作得很好,但是我已经编辑了所以整个对象被拖动而不仅仅是文本,但是由于某种原因这会消除克隆功能,即使我有帮助:克隆。 / p>

这是我的代码:

<script>
$(function() {
    $( "ul li" ).draggable({
        appendTo: "body",
        helper: "clone"});
    $( ".day #drag" ).draggable({
        appendTo: "body"});
    $( ".day" ).droppable({
        activeClass: "ui-state-hover",
        hoverClass: "ui-state-active",
        accept: ":not(.ui-sortable-helper)",
        drop: function( event, ui ) {
            var targetElem = $(this).attr("id");

            $( this ).addClass( "ui-state-highlight" );
            $( ui.draggable ).appendTo( this );
        }
    }).sortable({
        items: "li:not(.placeholder)",
        sort: function() {
            $( this ).removeClass( "ui-state-default" );
        }
    });
});
</script>

示例列:

<td>
   <div id="monday" class="day monday ui-widget-content"></div>
</td>

可拖动元素:

<li><div style="background-color:#<?=$bgColor?>;color:<?=$textColor?>;" id="drag" class="<?=$subject?>"><?=$row['name']?></div></li>

它本质上是一个时间表设置工具。谢谢你的帮助

这是一个供参考的jsFiddle:http://jsfiddle.net/x5T4h/

1 个答案:

答案 0 :(得分:3)

不确定它是否符合您的要求,但这是您的良好开端:http://jsfiddle.net/x5T4h/2/

基本上,我删除了第二个draggable对象声明,并添加了clone函数来复制drop事件$( ui.draggable ).clone().appendTo( this );

中的元素
$(function() {
    $( "ul li" ).each(function(){
        $(this).draggable({
            helper: "clone"
        });
    });

    $( ".day" ).droppable({
        activeClass: "ui-state-hover",
        hoverClass: "ui-state-active",
        accept: ":not(.ui-sortable-helper)",
        drop: function( event, ui ) {
            var targetElem = $(this).attr("id");
            $( ui.draggable ).clone().appendTo( this );
        }
    }).sortable({
        items: "li:not(.placeholder)",
        sort: function() {
            $( this ).removeClass( "ui-state-default" );
        }
    });
});​