当前位置: 首页 > 面试题库 >

在doc上执行写入:除非已明确打开,否则无法从异步加载的外部脚本写入文档。

明安阳
2023-03-14
问题内容

我试图在页面加载执行后加载某个脚本,如下所示:

function downloadJSAtOnload(){
            var element = document.createElement("script");
            element.src = "scriptSrc";
            document.body.appendChild(element);
        }

         if (window.addEventListener)
                  window.addEventListener("load", downloadJSAtOnload, false);
            else if (window.attachEvent)
                  window.attachEvent("onload", downloadJSAtOnload);
            else window.onload = downloadJSAtOnload;

尽管此脚本似乎执行并下载了“ scriptSrc”,并将其附加在body标签末尾之前,但它在控制台(chrome)中产生了以下消息(不是错误)

无法在“文档”上执行“写入”:无法通过异步加载的外部脚本写入文档,除非已明确打开该文档。

这到底是什么意思?我应该做些不同的事情吗?即使我得到了预期的行为?


问题答案:

在文档完全解析并关闭后,异步加载的脚本可能会运行。因此,您不能document.write()在这样的脚本中使用(从技术上讲可以,但是它不会做您想要的事情)。

您将需要document.write()通过创建DOM元素,然后使用.appendChild()or
.insertBefore()或设置.innerHTML或某种直接DOM操作的机制将它们插入到特定的父级中,从而用显式DOM操作替换该脚本中的任何语句。

例如,代替内联脚本中的此类代码:

<div id="container">
<script>
document.write('<span style="color:red;">Hello</span>');
</script>
</div>

您可以使用它来替换上面的内联脚本,以动态加载脚本:

var container = document.getElementById("container");
var content = document.createElement("span");
content.style.color = "red";
content.innerHTML = "Hello";
container.appendChild(content);

或者,如果容器中没有需要附加的其他内容,则可以简单地执行以下操作:

var container = document.getElementById("container");
container.innerHTML = '<span style="color:red;">Hello</span>';


 类似资料:
  • 问题内容: 我看到很多其他人都在问同样的问题,但是没有发布的解决方案对我有帮助。 我正在尝试从我的Android应用程序将(二进制)文件写入外部存储。我输入了清单,但仍然无法创建任何文件。我用来创建文件的代码是 对的调用失败,并引发(ENOENT,因为该目录不存在) 有人知道怎么回事吗?我什至尝试过重启设备。如果有任何区别,我使用的是Nexus 7的API级别8。 问题答案: 首先,您应该检查Ex

  • 我按照设置TwitterSource和HDFS汇的链接。 用于启动代理的命令: 我成功地做到了这一点,但现在有一个问题。在停止flume代理之前,输出不会被写入。一旦我杀了我的水槽代理,它就会被写到HDFS。 我有两个问题: 1)如何停止水槽剂 - 除了做CTRL C之外,还有其他方法吗? 2)我能让flume-agent在移动中向HDFS写信,而不必杀死代理吗? 注意:终止进程后,写入的文件。t

  • 我是android新手,有时找不到合适的解决方案,这就是其中之一。 我写了一个简单的应用程序来编写使用ITextPdf libray生成的内部pdf。这工作得很好,我可以从设备文件资源管理器中看到pdf文件。现在我正在使用外部存储做同样的事情,但在这种情况下,我不能在下载文件夹中生成文件。我找到了对我的代码不起作用的解决方案。 我的代码: java文件 我在中发现了问题。它返回-1,但我不明白它不

  • 我的设备是Android6.0.1操作系统,但无法将文件写入外部SD卡,从日志中,没有权限,但我有权申请成功,并在AndroidManifest中获得权限。xml文件; 我使用“adb shell dumpsys package packagename”命令,将读写权限返回到true;然后我看了一下设置- 我必须使用外部SD卡 有人遇到过这个问题吗我觉得这很奇怪 错误日志: 带系统。错误:java

  • 我的舱单中有权限条目: 编辑:我正在使用sdk 23

  • Often you may want to run external scripts that interact with your contracts. Truffle provides an easy way to do this, bootstrapping your contracts based on your desired network and connecting to your