解决方法
你可以这样做:
var theWindow = window.open('https://stackoverflow.com'),theDoc = theWindow.document,theScript = document.createElement('script'); function injectThis() { // The code you want to inject goes here alert(document.body.innerHTML); } theScript.innerHTML = 'window.onload = ' + injectThis.toString() + ';'; theDoc.body.appendChild(theScript);
这似乎也有效:
var theWindow = window.open('https://stackoverflow.com'),theScript = document.createElement('script'); function injectThis() { // The code you want to inject goes here alert(document.body.innerHTML); } // Self executing function theScript.innerHTML = '(' + injectThis.toString() + '());'; theWindow.onload = function () { // Append the script to the new window's body. // Only seems to work with `this` this.document.body.appendChild(theScript); };
如果由于某种原因你想使用eval:
var theWindow = window.open('https://stackoverflow.com'),theScript; function injectThis() { // The code you want to inject goes here alert(document.body.innerHTML); } // Self executing function theScript = '(' + injectThis.toString() + '());'; theWindow.onload = function () { this.eval(theScript); };
这是做什么的(第一部分代码的解释.所有例子都非常相似):
>打开新窗口
>获取对新窗口文档的引用
>创建一个脚本元素
>将您想要“注入”的所有代码放入函数中
>更改脚本的innerHTML以在窗口时加载所述函数
使用window.onload事件加载(也可以使用addEventListener).我使用toString()是为了方便,所以你不必连接一堆字符串. toString基本上将整个injectThis函数作为字符串返回.
>将脚本附加到新窗口的document.body,它实际上不会将它附加到加载的文档中,它会在加载之前附加它(到空体),这就是为什么你必须使用window.onload,以便您的脚本可以操作新文档.
使用window.addEventListener(‘load’,injectThis.toString())可能是个好主意;而不是window.onload,以防你的新页面中有一个使用window.onload事件的脚本(它会覆盖注入脚本).
请注意,您可以在injectThis函数内部执行任何操作:追加DIV,执行DOM查询,添加更多脚本等等…
另请注意,您可以使用此操作来处理theWindow.onload事件内的新窗口的DOM.
原文地址:https://www.jb51.cc/js/158851.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。