我认为window.onerror
在WebKit中无法正常工作(https://bugs.webkit.org/show_bug.cgi?id=8519)。不知道这是否已经修复,如果是这样,如果QT WebKit版本已经是最新的。
但是,您应该能够捕获代码中抛出的异常。如果您使用类似webPage.evaluate(...)
的代码来运行代码,则无法将完整的调用包装在try/catch块中,因为脚本是在不同的上下文中评估的,并且这些错误不会出现在主执行上下文中。相反,您需要捕获页面执行上下文中的错误。不幸的是,没有办法访问在主要上下文中定义的任何函数,因此我们必须明确地编写代码周围的包装代码来执行。
以下是PhantomJS源中包含的phantomwebintro.js
文件的修改示例。它加载一个HTML页面,插入一个脚本,然后在页面上下文中运行一些代码(这里有一行引发类型错误)。该代码被try/catch块封装,并将包装结果或错误对象返回到主要上下文。
...
// Load an HTML page:
page.open("http://www.phantomjs.org", function(status) {
if (status == "success") {
// Inject some scripts:
page.includeJs("http://ajax.googleapis.com/ajax/libs/jquery/1.6.1/jquery.min.js", function() {
// Run your own code in the loaded page context:
var resultWrapper = page.evaluate(function() {
var wrapper = {};
try {
// Your code goes here
// ...
var x = undefined.x; // force an error
// store your return values in the wrapper
wrapper.result = 42;
} catch(error) {
wrapper.error = error;
}
return wrapper;
});
// Handle the result and possible errors:
if (resultWrapper.error) {
var error = resultWrapper.error;
console.log("An error occurred: " + error.message);
// continue handling the error
// ...
} else {
var result = resultWrapper.result;
// continue using the returned result
// ...
}
...
});
}
});
...
我想你的意思是定义一个'window.onerror'函数,对吧? –
是的,固定的。谢谢! –