我正在尝试使用 insertBefore 将脚本添加到 dom。
当通过控制台运行命令时,脚本按预期执行,但是当通过代码运行相同的代码段时,它拒绝执行。
这是我正在使用的代码。
var el = document.getElementsByTagName('div')[0];
var s = document.createElement('script');
s.text = 'alert("abc");'
el.parentNode.insertBefore(s, el.nextSibling)
el.parentNode.replaceChild(s.childNodes[0], el);
el = s.childNodes[0];
for(var i = s.childNodes.length - 1; i >= 0 ; i--)
el.parentNode.insertBefore(s.childNodes[i], el.nextSibling);
这是将脚本添加到 DOM 但不执行它。
最佳答案
我无法重现您的问题:
http://jsfiddle.net/treeface/8F8bK/
您确定您的代码在 DOM 完全加载后正在运行吗?如果您不是,您可能想像这样运行此代码:
window.onload = function() {
var el = document.getElementsByTagName('div')[0];
var s = document.createElement('script');
s.text = 'alert("abc");'
el.parentNode.insertBefore(s, el.nextSibling)
};
关于javascript - 动态添加脚本标签到页面,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9529986/