8

我有一个父 html 页面,它使用 jquery 将具有源的动态 iframe 附加到另一个域。我已经设置了 X-Frame-Options 以允许这样做,并且加载纯内容不是问题。事实上,我所有的其他脚本似乎都运行良好。

在 iFrame 中加载的 html 页面使用jQuery DirtyForms 插件,该插件有几行看起来像$(document)。脏表单代码和 jQuery 脚本都是 iframe 文档的本地代码。

当任何这些行执行时,我在 Firefox 中收到以下错误(我尚未测试任何其他浏览器),错误:访问属性“文档”的权限被拒绝。

我一直在阅读这方面的内容,如果父页面试图访问孩子的脚本或反之亦然,这似乎是一个问题,但在我的情况下,出错的脚本是孩子本地的。

顺便提一句。未在 iFrame 中加载的子代码可以完美运行。

我现在不知所措,无法找到解决方法。

我假设 $(document) 以某种方式被评估为父级。

有什么方法可以纠正这种行为吗?也许通过修改插件代码。也许,$(document).find('contentWindow')...??

感谢您的帮助!谢谢。

4

2 回答 2

2

那么你不能访问它..现在的问题是为什么?

为此,只需通过以下链接

访问属性“文档”的权限被拒绝

错误:访问属性“文档”的权限被拒绝

在你的情况下,如果你想在页面加载时做任何事情,那么最好使用下面的 IFrame 代码

 <iframe ........ onload='yourFunction( this )'>
于 2014-05-07T04:53:00.430 回答
0

在 Dirty Forms 1.x 中,默认行为将事件处理程序附加到当前页面所在的任何父页面中的锚标记。执行此操作的代码如下所示:

$(top.document).on('click', 'a', aBindFn);
$(top.document).on('submit', 'form', formBindFn);

也就是说,它将事件处理程序附加到window.top.document. 您可以使用以下方法关闭该行为:

$.DirtyForms.watchParentDocs = false;

在 Dirty Forms 2.x 中,此行为已被删除,因为它仅适用于 iFrame 的一个特定用例(在 iFrame 中托管使用​​ Dirty Forms 的表单)。您现在可以自定义事件绑定,以根据您的页面的需要将事件处理程序附加到父(主机)页面或子 iFrame,但默认情况下不与 iFrame 交互。这应该使您能够解决诸如此类的问题。

于 2016-02-21T16:12:46.717 回答