这是一个容易重现的问题。检查这个jsFiddle:http: //jsfiddle.net/MichielCM/XEC9g/
<ul id="list1">
<li>Item 1</li>
<li>Item 2</li>
<li>Item 3</li>
<li>Item 4</li>
<li>Item 5</li>
<li>Item 6</li>
</ul>
<ul id="list2">
<li>Hover me over the items</li>
</ul>
<div id="status"></div>
List1 存在放置目标。它设置为最大高度并且其溢出被隐藏。List2 只有一个可拖动项目。
$("#list1 li").droppable({
greedy: true,
tolerance: "pointer",
over: function(event, ui) {
$("#status").text(
"Hovering over: ".concat($(this).text())
);
}
});
$("#list2 li").draggable();
现在,当将 list2 中的项目拖到 droppable 列表 (list1) 上时,每个目标的 'over' 事件都会被激活。甚至对于由于固定高度而未显示的不可见项目也会发生这种情况。这些物品也会触发“drop”事件,因此实际上可以将物品放在不可见的目标上!
有什么优雅的方法可以防止这种情况吗?谢谢。