使用原型(prototype)版本 1.6.0.2。
我有一个常见的问题,即异常在回调函数中被抛出时被吞没,通常是在我尝试处理对 Ajax.Request
调用的响应时。这是一个简单的例子:
HTML 标记:
<input type="button" id="myButton" value="Press Me" />
Javascript:
MYSITE = {};
document.observe("dom:loaded", function () {
// Set up our helper object
MYSITE.pageHelper = new MYSITE.PageHelper();
});
MYSITE.PageHelper = function() {
console.log("PageHelper called.");
$("myButton").observe("click", this.makeCall.bindAsEventListener(this));
};
MYSITE.PageHelper.prototype.makeCall = function() {
console.log("Make call.");
new Ajax.Request(
"remoteCall.cfm",
{
method: 'get',
parameters: "",
onComplete: this.handleCallback.bindAsEventListener(this)
});
};
MYSITE.PageHelper.prototype.handleCallback = function(resp) {
console.log("Start callback processing...");
var x = missingVar + "text"; // This line generates an exception...
console.log("Finished callback processing.");
};
好的,所以问题是,如果您在带有 Firebug 的 Firefox 中运行此代码,将不会为有问题的行输出异常 - 它被吞没了。囫囵吞枣。 我知道捕捉这些的唯一方法(比如我正在调试)是将回调函数的内容包装在 try/catch 中。例如:
MYSITE.PageHelper.prototype.handleCallback = function(resp) {
try {
console.log("Start callback processing...");
var x = missingVar + "text"; // This line generates an exception...
console.log("Finished callback processing.");
} catch (e) {
console.log(e);
}
};
有没有人遇到过这个问题?那里有任何解决方法吗?
提前致谢!
最佳答案
截至今天,这是已知行为:
这里有一张增强处理这些被吞噬的异常的票:
建议的一种解决方法是添加以下代码(感谢 Glenn Maynard!):
Ajax.Responders.register({
onException: function(request, exception) {
(function() { throw exception; }).defer();
}
});
希望在实现更永久的解决方案之前帮助其他人解决同样的问题。
关于javascript - 原型(prototype)回调函数吞噬异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2601411/