我在 iframe 外面有一个可拖动的东西,里面有一个可放置的目标。在这里,我将 iframe 显示为包含由其 src 属性加载的 HTML 片段。
<div id="draggables">
<img src="drag-me.gif">
</div>
<iframe src="iframe-src.html" id="iframe">
<!-- HTML gubbins -->
<div id="droppable"> </div>
<!-- More HTML gubbins -->
</iframe>
我使用一些 jQuery(UI 可拖动/可拖放)来做一些事情:
$("#iframe").load(function() {
var $this = $(this);
var contents = $this.contents();
contents.find('#droppable').droppable({
drop: function (event, ui) { alert('dropped'); }
});
$('#draggables img').draggable();
});
可拖动对象变为可拖动对象,并且可放置对象成功成为放置目标。问题是放置区域的着陆区域不在屏幕上显示的位置。也就是说,当可拖动对象被拖放到放置目标上方的某个位置时会触发警报,而不是在目标本身上。
我所做的一些测试表明,目标在屏幕上的位置与 jQuery 认为的位置之间的差异与页面上 iframe 的垂直位置有关,但我找不到直接的相关性。有谁知道这个问题是否已经被任何地方的任何人调查过,并且可能已经解决了?
如果做不到这一点,任何人都可以建议一种方法,我可以在不使用 iframe 并且两个页面的结构和样式不会相互干扰的情况下将外部 HTML 文件加载到我的页面中吗?我正在考虑直接加载内页并使用 javascript 在它周围绘制页面控件。
TIA奥特柔斯