我正在尝试将外部JavaScript文件动态加载到HTML元素中以预览广告代码。脚本加载并执行但脚本包含“document.write”,它有一个问题正确执行但没有错误。
<html>
<head>
<script src="//ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js"></script>
<script type="text/javascript">
$(function() {
source = 'http://ib.adnxs.com/ttj?id=555281';
// DOM Insert Approach
// -----------------------------------
var script = document.createElement('script');
script.setAttribute('type', 'text/javascript');
script.setAttribute('src', source);
document.body.appendChild(script);
});
</script>
</head>
<body>
</body>
</html>
如果
,我可以让它发挥作用我无法修改脚本,因为它是由第三方生成和托管的。
有谁知道为什么document.write无法正常工作?有没有办法解决这个问题?
感谢您的帮助!
答案 0 :(得分:7)
另一个解决方案是创建一个iframe,然后在ajax调用就绪时在iframe中加载脚本:
var iframe = document.createElement('iframe');
document.body.appendChild(iframe);
var doc = iframe.contentWindow.document;
// do this whenever you want (f.ex after ajax is made):
doc.open();
doc.write('<script src="http://ib.adnxs.com/ttj?id=555281">\x3C/script>');
doc.close();
这样,结尾脚本中的document.write
不会影响您的网站,只会影响iframe。您需要设置iframe样式以适合广告。
答案 1 :(得分:1)
如果外部脚本标记还包含document.write
,则异步加载外部脚本标记可能会有危险。因此,我建议您在最后使用document.write
:
document.write('\x3Cscript src="http://ib.adnxs.com/ttj?id=555281">\x3C/script>');
或者只是一个脚本标签(duh):
<script src="http://ib.adnxs.com/ttj?id=555281"></script>
答案 2 :(得分:0)
你document.write
上的不想要$(function()
(当dom准备就绪时)
删除document .ready
包装。
移动你的 - </body>
之前。 (或容器位置 - 您希望窗口小部件显示的位置。)
所以:
<html>
<head>
<script src="//ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js"></script>
</head>
<body>
//bla bla...
<script type="text/javascript">
(function (){
var source = 'http://ib.adnxs.com/ttj?id=555281';
// DOM Insert Approach
// -----------------------------------
var script = document.createElement('script');
script.setAttribute('type', 'text/javascript');
script.setAttribute('src', source);
document.body.appendChild(script);
})();
</script>
</body>
</html>
重要提示:
答案 3 :(得分:0)
我遇到了同样的问题,想出了一个解决方案。我认为我的情况稍微复杂一点,因为我的布局是在客户端生成的,在dom-ready之后,这意味着我无法使用这种方式渲染脚本。这为我增加了一个额外的步骤,但如果您的布局是在服务器端生成的,那么它可能不是一个额外的步骤。
如果你能够在服务器上渲染脚本包括它应该在哪里,那么就这样做,你就完成了。否则: