我在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});
    });

08-17 20:27