我在iframe外部有一个可拖动的jQuery。我需要在iframe可放置对象中添加元素。当我在iframe上拖动时,“ over”事件不会触发,但是如果我继续在iframe上方拖动,则“ over”事件会触发。
看起来这也贴在这里,但从未回答。
jQuery and iframes and weird positioning: is there a workaround?
编辑:代码示例
html
<div id="draggable">
</div>
<iframe id="iframe"/>
javascript
$("#draggable").draggable();
var body = $('#iframe').contents().find('body');
$(body).droppable({
over:function(event,ui) {
alert('over droppable');
}
});
最佳答案
我认为您可以使用像这样的代码。
html
<!DOCTYPE html>
<html lang="en" xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta charset="utf-8" />
<title></title>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<script src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.10.3/jquery-ui.min.js"></script>
</head>
<body>
<div style="width:400px; height:200px; overflow:auto">
<iframe src="iframe.html" style="width:400px; height:400px;"></iframe>
</div>
<div style="width:60px; height:60px; background-color: #808080" id="drag"></div>
</body>
</html>
javascript
$(function () {
$("iframe").load(function () {
var iframe = $(this).contents();
iframe.find('#iframe_container').droppable(
{
iframeFix: true,
drop: function (event, ui) { alert('dropped'); }
});
});
$('#drag').draggable({iframeFix: true});
});