2

这是我的testing.html:

<html>
<meta charset="utf-8">
<script>
window.onload = function() {
    var a = document.getElementById("divid");
    var ifr = document.createElement('iframe');
    a.appendChild(ifr);
    ifr.contentDocument.body.style.cssText = (
      'margin: 0px;' +
      'padding: 0px;' +
      'height: 100%;' +
      'width: 100%;');
}
</script>

<head></head>
<body>
<div id="divid"/>
</body>
</html>

此处 ifr.contentDocument.body.style.cssText = (...) 在 chrome 上运行良好,但在 Firefox 上运行良好。它是Firefox的错误吗?有什么解决方法吗?

找到解决方法:看起来 Firefox 中有一个奇怪的种族错误。使用 setTimeout 的以下解决方法将使此工作正常,如下所示:

<html>
<meta charset="utf-8">
<script>
window.onload = function() {
    var a = document.getElementById("divid");
    var ifr = document.createElement('iframe');
    ifr.id = "fid";
    a.appendChild(ifr);
    setTimeout (function() {
        ifr.contentDocument.body.style.cssText = (
        'margin: 0px;' +
        'padding: 0px;' +
        'height: 100%;' +
        'width: 100%;');
    }, 100);
}
</script>

<head></head>
<body>
<div id="divid"/>
</body>
</html>
4

2 回答 2

5

当您在 Firefox 中附加 iframe 时,它​​会开始about:blank异步加载 iframe。然后你触摸文档,所以它必须在其中同步创建一个about:blank文档,然后你修改它。然后异步加载完成并替换您修改的文档。

在修改它之前等待框架上的加载事件触发。

于 2013-05-05T11:59:23.000 回答
0

试试这个:

 ifr.contentDocument.getElementsByTagName('body')[0].style.cssText = (
  'margin: 0px;' +
  'padding: 0px;' +
  'height: 100%;' +
  'width: 100%;');

<div id="divid"> </div>
于 2013-05-05T05:34:31.730 回答