我有一个非常简单的greasemonkey脚本,我想在页面上调用已经存在的javascript函数。我已阅读文档,似乎没有任何工作
window.setTimeout(function() {
alert('test') // This alert works, but nothing after it does
myFunction() // undefined
window.myFunction() // undefined
document.myFunction() // undefined
}, 1000);
尝试使用:unsafeWindow.myFunction();
更多细节和信息 - http://wiki.greasespot.net/UnsafeWindow
在原始页面中调用函数的一种方法是这样的:
location.href = "javascript:void(myFunction());";
这有点难看。还有GreaseMonkey提供的unsafeWindow,但作者建议不要使用它。
unsafeWindow.myFunction();
看起来更整洁,但要确保你了解其后果。从手册:
unsafeWindow绕过Greasemonkey的基于XPCNativeWrapper的安全模型,该模型的存在是为了确保恶意网页不会改变对象,从而使paintmonkey脚本(以比网页中运行的普通Javascript更多的权限执行)执行其作者的操作或用户不打算。因此,用户脚本应该避免调用或以任何其他方式取决于unsafeWindow上的任何属性 - 特别是如果它们是针对任意网页执行的,例如@include *,其中页面作者可能以这种方式颠覆了环境。
换句话说,如果使用unsafeWindow,则脚本会提升原始页面脚本的可用权限。
您可以尝试使用javascript事件侦听器。
这些执行代码响应发生的对象事件(例如页面加载)
例如,要在页面加载时执行代码:
window.addEventListener('load', function ()
{
/* code goes here */
}