以编程方式将元素拖放到另一个元素上

时间:2013-05-31 00:50:15

标签: javascript jquery jquery-ui draggable droppable

使用jQuery UI,是否可以执行拖动和放大使用javascript删除操作?

Example。点击链接后,拖动#pony并将其放入#box。我已经尝试触发拖动事件,但这似乎不起作用:)

$('#pony').trigger('drag', [$('#box')]);

2 个答案:

答案 0 :(得分:13)

这是jQuery UI团队以编程方式触发drop事件的方式。

droppable_events.js

draggable = $( "#draggable1" ).draggable(),
droppable1 = $( "#droppable1" ).droppable( config ),
droppable2 = $( "#droppable2" ).droppable( config ),

droppableOffset = droppable1.offset(),
draggableOffset = draggable.offset(),
dx = droppableOffset.left - draggableOffset.left,
dy = droppableOffset.top - draggableOffset.top;

draggable.simulate( "drag", {
    dx: dx,
    dy: dy
});

simulate函数在jquery.simulate.js中定义。简单来说,它将draggable移动到droppable上以触发drop事件。

完全放上这个,我们有以下片段。欢呼声。

$(function() {
  $("#draggable").draggable();
  $("#droppable").droppable({
    drop: function(event, ui) {
      console.log(event, ui);
      alert('dropped!');
    }
  });
});

function trigger_drop() {
  var draggable = $("#draggable").draggable(),
    droppable = $("#droppable").droppable(),

    droppableOffset = droppable.offset(),
    draggableOffset = draggable.offset(),
    dx = droppableOffset.left - draggableOffset.left,
    dy = droppableOffset.top - draggableOffset.top;

  draggable.simulate("drag", {
    dx: dx,
    dy: dy
  });
}
#draggable {
  width: 100px;
  height: 100px;
  padding: 0.5em;
  float: left;
  margin: 10px 10px 10px 0;
}
#droppable {
  width: 150px;
  height: 150px;
  padding: 0.5em;
  float: left;
  margin: 10px;
}
br {
  clear: both;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

<link rel="stylesheet" href="https://ajax.googleapis.com/ajax/libs/jqueryui/1.11.3/themes/smoothness/jquery-ui.css" />
<script src="https://ajax.googleapis.com/ajax/libs/jqueryui/1.11.3/jquery-ui.min.js"></script>

<script src="https://rawgit.com/jquery/jquery-ui/1-11-stable/external/jquery-simulate/jquery.simulate.js"></script>


<div id="draggable" class="ui-widget-content">
  <p>Drag me to my target</p>
</div>

<div id="droppable" class="ui-widget-header">
  <p>Drop here</p>
</div>
<br>
<button onclick="trigger_drop()">trigger drop event</button>

答案 1 :(得分:1)

  • 如果要激发实际上通过鼠标拖放对象时发生的相同功能,可以将您的拖放脚本封装到一个函数中,然后您也可以在其他地方调用它。

    < / LI>
  • 如果您想要拖动项目的动画动作,请执行以下操作:你应该.stop().animate({})到目标位置,接着是上面的步骤。

  • 如果您只想将其附加到放置目标,只需.appendTo($('#yourtargetid'));

对不起,如果我不理解任何事情,我的声誉就不足以事先问你,就像我在其他地方所做的一样。