我正在使用 jquery 的可拖动和可放置来实现拖放功能:有两个选项卡,每个选项卡都包含一个带有可拖动的可放置区域。现在我可以选择一个可拖动的并将其移动到另一个选项卡 - 当我在拖动过程中移动选项卡时选项卡会发生变化。(就像 MS WinExplorer,如果您将文件从一个目录移动到另一个目录......)。为了表明用户位于可放置区域之上,我使用了 hoverClass 选项。
问题:在拖动过程中多次更改选项卡后,悬停效果丢失。如果浏览器大小需要滚动条,并且我将带有可拖动的指针移动到浏览器边框之一(以便浏览器滚动),则会显示悬停效果...。我已经将过度事件添加到 droppable 以检查它是否总是被触发 - 但事实并非如此。
$('.drag').draggable({
revert: 'invalid',
helper: function () {
return $('<div></div>').addClass('drag-dragging').appendTo('body').text($(this).text());
}
});
$('#panel-1-droppable,#panel-2-droppable').droppable({
accepts: 'drag',
hoverClass: 'panel-dropover',
over: function () {
// just to check the over-event
$('#over-state').text('Mouseover with draggable [' + $(this).attr('id') + ']');
}
});
$('.panel-tab').droppable({
over: function () {
// changing tab...
}
});
我创建了一个测试场景来重现问题:http: //jsfiddle.net/CKYJs/5/
我希望我已经提供了所有必要的信息......