jQuery UI - 拖放后不能立即工作

标签 jquery html css jquery-ui drag-and-drop

HTML:

<div class="character_list">
   <div id="draggable" class="character_list_container">
      <div><img  class="1" src="http://ahna.web44.net//img/charas/13.png" /></div>
      <div><img class="2" src="http://ahna.web44.net//img/charas/13.png" /></div>
      <div><img class="3" src="http://ahna.web44.net//img/charas/13.png" /></div>
      <div><img  class="4" src="http://ahna.web44.net//img/charas/13.png" /></div>
      <div><img class="5" src="http://ahna.web44.net//img/charas/13.png" /></div>
      <div><img class="6" src="http://ahna.web44.net//img/charas/13.png" /></div>
   </div>
   <div id="droppable_slots" class="current_team">
      <div id="slot" class="1">1</div>
      <div id="slot" class="2">2</div>
      <div id="slot" class="3">3</div>
   </div>
</div>​

jQuery:

$(function() {
    $("#draggable>div>img").draggable({
        start: function(){
           $(this).css({display: 'none'});
        },
        stop: function(){
           $(this).css({display: 'block'});
        },
        revert: function(dropped) {
           var dropped = dropped && dropped[0].id== "slot";
           if(!dropped) {
              $(this).appendTo($(this).data('originalParent'))
            }
            return !dropped;
        },
        helper: function() { return $(this).clone().appendTo('body').show(); },
        containment: '.sel_screen_left'
}).each(function() {
    $(this).data('originalParent', $(this).parent())
});

$("#droppable_slots>div").droppable({
    drop: function(event, ui) {

        var $this = $(this);
    var content = $.trim($this.html()).length;
    if(content > 0) {
    $this.html("");
    }
        $this.append(ui.draggable);    

        var width = $this.width();
        var height = $this.height();
        var cntrLeft = (width / 2) - (ui.draggable.width() / 2);
        var cntrTop = (height / 2) - (ui.draggable.height() / 2);

        ui.draggable.css({
            left: cntrLeft + "px",
            top: cntrTop + "px"
        });

}
});
});​

实例:http://jsfiddle.net/CVbzg/3/

正如您在 jsfiddle 示例中看到的那样,当图像被放下时,它会完美锁定,但是当您移出放置区域时,它会失去可拖动性,而不是恢复并附加到其原始父级。

有人可以帮忙吗?

最佳答案

当您将 droppable 放置在放置目标中并稍微移动它时,它失去了可拖动性,这是因为

$this.html("");

在放置处理程序中,可拖动对象仍在放置目标内。当您删除放置目标的 HTML 时,您还删除了应该重新附加的元素。这将返回一个语法错误,因为该元素不再存在,这会中断操作,将克隆留在那里并删除可拖动对象。

这是一个快速修复:

drop: function(event, ui) {

    var $this = $(this);
    if ($this.find('.ui-draggable').length) return; //don't overwrite occupied spot
    $this.empty(); //empty() sounds more semantic than html('') for me, it does the same thing =]
    $this.append(ui.draggable);
    //...
}

Fiddle

它不允许用另一个元素覆盖放置目标内的放置元素,包括将元素重新放置在它们自己的放置目标上。


另一种解决方案是在附加被拖放的可拖动对象之前将已经拖放的可拖动对象移回其起始位置:

drop: function(event, ui) {
    var $this = $(this),
        containsDropped = $this.find('.ui-draggable');
    if (containsDropped.length) containsDropped.appendTo(containsDropped.data('originalParent'));
    $this.empty();

Fiddle

您只需要注意不要无意中删除可拖动对象。 =]

关于jQuery UI - 拖放后不能立即工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14167965/

相关文章:

html - WordPress:有条件的动态菜单

php - 如何在 googlemaps 页面中使用文本文件中的 GPS 坐标?

html - 将鼠标悬停在上方时不会触发转换

css - 如何在 WordPress 的文本小部件中定位特定的文本行?

css - 在模态中实现标签不显示内容

javascript - 获取 jQuery() 选择的默认(?)元素

javascript - Jquery 可对动态创建的 div 进行排序

javascript - 未使用 JSONP API 中的信息创建对象

html - 输入框被切断

javascript - 如何自动填写我的表单,就像我们通过serialize()获取值一样?